}\r\n */\r\nfunction processFileWH(objFile, intIndex, intMaxWidth, intMaxHeight, fltQuality, strImgType, blnForceResize) {\r\n return new Promise((resolve, reject) => {\r\n try {\r\n if (!(window.File && window.FileReader && window.FileList && window.Blob)) {\r\n console.error(\"The File APIs are not fully supported in this browser.\");\r\n resolve(false);\r\n return;\r\n }\r\n\r\n if (!/image/i.test(objFile.type)) {\r\n console.error(\"File \" + objFile.name + \" is not an image.\");\r\n resolve(false);\r\n return;\r\n }\r\n\r\n // read the files\r\n let reader = new FileReader();\r\n reader.readAsArrayBuffer(objFile);\r\n\r\n reader.onload = (event) => {\r\n // blob stuff\r\n var blob = new Blob([event.target.result]); // create blob...\r\n window.URL = window.URL || window.webkitURL;\r\n let blobURL = window.URL.createObjectURL(blob); // and get it's URL\r\n\r\n // helper Image object\r\n let objImg = new Image();\r\n objImg.src = blobURL;\r\n\r\n objImg.onload = () => {\r\n // have to wait till it's loaded\r\n\r\n if (!strImgType) {\r\n strImgType = objFile.type;\r\n }\r\n\r\n let canvas = document.createElement(\"canvas\");\r\n\r\n let width = objImg.width;\r\n let height = objImg.height;\r\n\r\n // calculate the width and height, constraining the proportions\r\n if (blnForceResize) {\r\n width = intMaxWidth;\r\n height = intMaxHeight;\r\n } else {\r\n if (width > height) {\r\n if (width > intMaxWidth) {\r\n //height *= intMaxWidth / width;\r\n height = Math.round((height *= intMaxWidth / width));\r\n width = intMaxWidth;\r\n }\r\n } else {\r\n if (height > intMaxHeight) {\r\n //width *= intMaxHeight / height;\r\n width = Math.round((width *= intMaxHeight / height));\r\n height = intMaxHeight;\r\n }\r\n }\r\n }\r\n\r\n if (!canvas.getContext) {\r\n console.error(\"Canvas are not fully supported in this browser.\");\r\n resolve(false);\r\n return;\r\n }\r\n\r\n // resize the canvas and draw the image data into it\r\n canvas.width = width;\r\n canvas.height = height;\r\n\r\n let ctx = canvas.getContext(\"2d\");\r\n ctx.drawImage(objImg, 0, 0, width, height);\r\n\r\n let dataURL = canvas.toDataURL(strImgType, fltQuality); // get the data from canvas as 70% JPG (can be also PNG, etc.)\r\n\r\n resolve(dataURL);\r\n\r\n canvas.onerror = (error) => {\r\n console.error(`Error occurred while canvas initialized.\\n${error.toString()}`);\r\n resolve(false);\r\n };\r\n };\r\n\r\n objImg.onerror = () => {\r\n console.error(`Error occurred when loading image: ${objFile.name}.`);\r\n resolve(false);\r\n };\r\n };\r\n\r\n reader.onerror = (error) => {\r\n console.error(`Error occurred reading file: ${objFile.name}.\\n${error.target.error}`);\r\n resolve(false);\r\n };\r\n } catch (error) {\r\n console.error(error);\r\n resolve(false);\r\n }\r\n });\r\n}\r\n\r\n\r\n///////////////////////////////////////////////////////////////////////////////////////////////////////////////\r\n\r\nasync function downloadFile(objFile) {\r\n try {\r\n const element = document.createElement(\"a\");\r\n const file = objFile;\r\n element.href = URL.createObjectURL(file);\r\n element.download = file.name;\r\n document.body.appendChild(element);\r\n element.click();\r\n\r\n return true;\r\n } catch (error) {\r\n console.error(error);\r\n return false;\r\n }\r\n}","import { useRef, useState } from \"react\";\r\nimport { resizeImgKB, resizeImgWH } from \"../cbmisUploader/rezieImageFun\";\r\n// import { ImagesContext } from \"../contextApi/contexts/images\";\r\n// import * as cbmisFunction from \"../../cbmisHelper/forDev/cbmisFunction\";\r\nconst useCamera = (videoRef, photoRef, constraints, front, setFront,maxFilesNumber=1,maxWidthImage) => {\r\n\r\n const imageUrl =useRef()\r\n const [imagesList, setImagesList] = useState([])\r\n const [tookPhoto, setTookPhoto] = useState(false)\r\n const [showIndex, setShowIndex] = useState(-1)\r\n let nummaxFilesNumber=Number(maxFilesNumber)\r\n const getVideo = () => {\r\n navigator.mediaDevices.getUserMedia(constraints)\r\n .then(stream => {\r\n const video = videoRef.current;\r\n video.srcObject = stream\r\n video.play();\r\n }).catch(err => {\r\n console.log(err)\r\n })\r\n }\r\n\r\n // stop only camera\r\n function stopVideo() {\r\n const video = videoRef.current;\r\n const stream = video.srcObject;\r\n const tracks = stream.getTracks();\r\n tracks.forEach(function(track) {\r\n track.stop();\r\n });\r\n video.srcObject=null\r\n }\r\n\r\n const takePicture = () => {\r\n const width = window.innerWidth\r\n const height = width / (13 / 9)\r\n let video = videoRef.current\r\n let photo = photoRef.current\r\n photo.width = width\r\n photo.height = height\r\n let ctx = photo.getContext('2d')\r\n ctx.drawImage(video, 0, 0, width, height)\r\n setTookPhoto(true)\r\n imageUrl.current = photo.toDataURL('image/jpeg', 0.5)\r\n }\r\n\r\n const updateStorage = (setVisibility) => {\r\n try {\r\n setVisibility(true)\r\n setTimeout(() => {\r\n setVisibility(false)\r\n }, 4000);\r\n } catch (error) {\r\n throw new Error(error)\r\n }\r\n\r\n }\r\n\r\n\r\n const flipCam = () => {\r\n setFront(!front)\r\n }\r\n\r\n const closePicture = () => {\r\n setTookPhoto(false)\r\n }\r\n\r\n const showImage = (index) => {\r\n setShowIndex(index)\r\n }\r\n\r\n const changeImageName=(event)=>{\r\n const index = event.target.id\r\n const newName = event.target.value\r\n imagesList[index] = {name:newName,url:imageUrl.current}\r\n }\r\n\r\n const saveImage = () => {\r\n if(imagesList.length < nummaxFilesNumber){\r\n imagesList.push({name:`image${imagesList.length+1}`,url:imageUrl.current})\r\n }else{\r\n imagesList[nummaxFilesNumber-1]={name:`image${nummaxFilesNumber}`,url:imageUrl.current}\r\n }\r\n setImagesList([...imagesList])\r\n setTookPhoto(false)\r\n }\r\n\r\n const deleteImage = (imgIndex) => {\r\n const newImagesList= imagesList.filter((_,index)=>index !== imgIndex)\r\n setImagesList(newImagesList)\r\n }\r\n\r\n async function resizeCameraImage(imagesList,imageSizeKB,maxWidth,maxHeight,quality,maxFilesNumber,blnDownload=false) {\r\n let lstResultFile = [];\r\n for (var i = 0; i < imagesList.length; i++) {\r\n let fileNew = await fetch(imagesList[i].url);\r\n let blob = await fileNew.blob();\r\n let strFileName = `${imagesList[i].name}.jpg`;\r\n let strNewFileType = \"image/jpeg\";\r\n\r\n let newObjFile = new File([blob], strFileName, { type: strNewFileType });\r\n // Object.defineProperty(newObjFile, 'size', { value: sizeKb * 1024 + 1 })\r\n if(i < maxFilesNumber){\r\n lstResultFile.push(newObjFile);\r\n }else{\r\n lstResultFile[maxFilesNumber - 1] = newObjFile\r\n }\r\n\r\n // if (blnDownload) {\r\n // await cbmisFunction.downloadResizeFile(newObjFile);\r\n // }\r\n }\r\n if(imageSizeKB){\r\n lstResultFile = resizeImgKB(lstResultFile,imageSizeKB,maxFilesNumber,quality,blnDownload)\r\n }else if(maxWidth||maxHeight){\r\n lstResultFile = resizeImgWH(lstResultFile,maxWidth,maxHeight,quality,maxFilesNumber,blnDownload)\r\n }\r\n return lstResultFile \r\n }\r\n\r\n return {\r\n getVideo,\r\n stopVideo,\r\n takePicture,\r\n tookPhoto,\r\n closePicture,\r\n flipCam,\r\n showImage,\r\n saveImage,\r\n front,\r\n deleteImage,\r\n updateStorage,\r\n imagesList,\r\n showIndex,\r\n changeImageName,\r\n resizeCameraImage\r\n }\r\n}\r\n\r\nexport default useCamera","import React from 'react'\r\nimport Icon from '../../../icon/CbmisIcon'\r\n\r\nconst CamFeatureBtn = (props) => {\r\n const { top, right, bottom, left, icon, func, extraClass,color } = props\r\n return (\r\n \r\n \r\n \r\n )\r\n}\r\n\r\nexport default CamFeatureBtn\r\n","import React, { useEffect, useRef, useState } from 'react'\r\nimport \"./camera.css\"\r\nimport useCamera from '../useCamera'\r\nimport CamFeatureBtn from '../cam-feature-btn/CamFeatureBtn';\r\nimport Icon from \"../../../icon/CbmisIcon\";\r\nimport * as permissionsVariable from \"../../CbmisPermissions/PermissionsVariable/PermissionsVariable\"\r\n\r\nimport PermissionControl from '../../CbmisPermissions/PermissionControl';\r\n\r\n\r\nfunction Camera(props) {\r\n const {open,eventClose,maxFilesNumber,blnDownload,appPermissionState,changeAppPermissionState,lang,color,blnChangeName,imageSizeKB,maxWidth,maxHeight,quality} =props\r\n const permissionType = permissionsVariable.objPermissionKey.cameraPermission\r\n const videoRef = useRef()\r\n const photoRef = useRef()\r\n\r\n const [front, setFront] = useState(false)\r\n\r\n const constraints = {\r\n video: {\r\n width: 1920,\r\n height: 1080,\r\n facingMode: front ? \"user\" : \"environment\"\r\n }\r\n };\r\n\r\n const {\r\n getVideo,\r\n stopVideo,\r\n takePicture,\r\n closePicture,\r\n tookPhoto,\r\n flipCam, // test \r\n saveImage,\r\n imagesList,\r\n showImage,\r\n deleteImage,\r\n showIndex,\r\n changeImageName,\r\n resizeCameraImage // kb\r\n } = useCamera(videoRef, photoRef, constraints, front, setFront,maxFilesNumber)\r\n\r\n useEffect(() => {\r\n if(open){\r\n if(((appPermissionState?.[permissionType].user && appPermissionState?.[permissionType].system)&& appPermissionState) || !appPermissionState){\r\n getVideo()\r\n }\r\n\r\n document.body.style.overflowY = 'hidden';\r\n }\r\n return()=>{\r\n document.body.style.overflowY = '';\r\n }\r\n }, [videoRef,open,appPermissionState])\r\n\r\n const handelClose=async()=>{\r\n stopVideo()\r\n let FilesList = await resizeCameraImage(imagesList,imageSizeKB,maxWidth,maxHeight,quality,maxFilesNumber,blnDownload);\r\n if(eventClose){\r\n eventClose(FilesList)\r\n }\r\n // document.body.style.overflowY = '';\r\n }\r\n\r\n\r\n\r\n const handelChangePermatision=()=>{\r\n if(changeAppPermissionState){\r\n changeAppPermissionState({...appPermissionState})\r\n }\r\n }\r\n\r\n useEffect(() => {\r\n }, [appPermissionState])\r\n \r\n return (\r\n open?\r\n (\r\n \r\n
\r\n
\r\n
\r\n
\r\n
\r\n {\r\n (!appPermissionState?.[permissionType].user || !appPermissionState?.[permissionType].system)&& appPermissionState?(\r\n
\r\n ):null\r\n }\r\n
\r\n
\r\n \r\n \r\n \r\n
\r\n
-1 ? 'camera-tookPhoto' : '')}>\r\n
\r\n
showImage(-1)}\r\n />\r\n {showIndex1?\r\n showImage(showIndex+1)}\r\n />\r\n :null}\r\n\r\n {showIndex>0 && imagesList.length>1?\r\n showImage(showIndex-1)}\r\n />\r\n :null}\r\n {\r\n blnChangeName?(\r\n \r\n \r\n
\r\n ):null\r\n }\r\n \r\n \r\n
\r\n {\r\n imagesList.map((img,index)=>{\r\n return(\r\n
\r\n
\r\n
\r\n {deleteImage(index)}} />\r\n {showImage(index)}} />\r\n
\r\n
{showImage(index)}} \r\n alt=\"\" />\r\n
\r\n
\r\n )\r\n })\r\n }\r\n
\r\n\r\n
\r\n )\r\n :null\r\n)\r\n}\r\n\r\nexport default Camera","\n import API from \"!../../../../node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js\";\n import domAPI from \"!../../../../node_modules/style-loader/dist/runtime/styleDomAPI.js\";\n import insertFn from \"!../../../../node_modules/style-loader/dist/runtime/insertBySelector.js\";\n import setAttributes from \"!../../../../node_modules/style-loader/dist/runtime/setAttributesWithoutAttributes.js\";\n import insertStyleElement from \"!../../../../node_modules/style-loader/dist/runtime/insertStyleElement.js\";\n import styleTagTransformFn from \"!../../../../node_modules/style-loader/dist/runtime/styleTagTransform.js\";\n import content, * as namedExport from \"!!../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[1].use[1]!./uploadImage.css\";\n \n \n\nvar options = {};\n\noptions.styleTagTransform = styleTagTransformFn;\noptions.setAttributes = setAttributes;\n\n options.insert = insertFn.bind(null, \"head\");\n \noptions.domAPI = domAPI;\noptions.insertStyleElement = insertStyleElement;\n\nvar update = API(content, options);\n\n\n\nexport * from \"!!../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[1].use[1]!./uploadImage.css\";\n export default content && content.locals ? content.locals : undefined;\n","\n import API from \"!../../../node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js\";\n import domAPI from \"!../../../node_modules/style-loader/dist/runtime/styleDomAPI.js\";\n import insertFn from \"!../../../node_modules/style-loader/dist/runtime/insertBySelector.js\";\n import setAttributes from \"!../../../node_modules/style-loader/dist/runtime/setAttributesWithoutAttributes.js\";\n import insertStyleElement from \"!../../../node_modules/style-loader/dist/runtime/insertStyleElement.js\";\n import styleTagTransformFn from \"!../../../node_modules/style-loader/dist/runtime/styleTagTransform.js\";\n import content, * as namedExport from \"!!../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[1].use[1]!./uploader.css\";\n \n \n\nvar options = {};\n\noptions.styleTagTransform = styleTagTransformFn;\noptions.setAttributes = setAttributes;\n\n options.insert = insertFn.bind(null, \"head\");\n \noptions.domAPI = domAPI;\noptions.insertStyleElement = insertStyleElement;\n\nvar update = API(content, options);\n\n\n\nexport * from \"!!../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[1].use[1]!./uploader.css\";\n export default content && content.locals ? content.locals : undefined;\n","import React from 'react'\r\nimport \"./uploader.css\"\r\nimport {resizeImgKB,resizeImgWH} from \"./rezieImageFun\"\r\n\r\nfunction Uploader({images,setImages, maxFilesNumber,maxSizeKB,maxWidth,maxHeight,quality}) {\r\n\r\n\r\n async function changeImage(e){\r\n let litsFile= []\r\n if(maxSizeKB){\r\n litsFile = await resizeImgKB(Array.from(e.currentTarget.files),maxSizeKB,maxFilesNumber,quality,false)\r\n }else if(maxWidth || maxHeight){\r\n resizeImgWH(Array.from(e.currentTarget.files),maxWidth,maxHeight,quality,maxFilesNumber)\r\n }\r\n else{\r\n litsFile = []\r\n Array.from(e.currentTarget.files).forEach((file,index)=>{\r\n if(index < Number(maxFilesNumber)){\r\n litsFile.push(file);\r\n }\r\n })\r\n }\r\n setImages(litsFile)\r\n }\r\n\r\n return (\r\n \r\n 1}\r\n />\r\n \r\n )\r\n}\r\n\r\nexport default Uploader","import React from 'react'\r\nimport Uploader from '../../Uploader'\r\nimport Icon from \"../../../../icon/CbmisIcon\"\r\n\r\nfunction UploaderImageBox(props) {\r\n const {images,setImages,gallery,camera,handelOpenCamera,maxSizeKB,maxFilesNumber,maxWidth,maxHeight,quality} = props\r\n return (\r\n \r\n \r\n
\r\n { images.length?\r\n
\r\n :\r\n
\r\n }\r\n \r\n
\r\n {\r\n !gallery?null:(\r\n \r\n \r\n \r\n \r\n )\r\n }\r\n {\r\n !camera?null:(\r\n \r\n \r\n \r\n )\r\n }\r\n
\r\n
\r\n \r\n )\r\n}\r\n\r\nexport default UploaderImageBox","import React from 'react'\r\nimport Uploader from '../../Uploader'\r\nimport Icon from \"../../../../icon/CbmisIcon\"\r\n\r\nfunction UploaderImageMultipleBox(props) {\r\n const {images,setImages,gallery,camera,handelOpenCamera,handleDeleteFile,handlePreview,maxSizeKB,maxFilesNumber,maxWidth,maxHeight,quality} = props\r\n\r\n return (\r\n \r\n \r\n
\r\n {\r\n !gallery?null:(\r\n \r\n \r\n \r\n \r\n )\r\n }\r\n {\r\n !camera?null:(\r\n \r\n \r\n \r\n )\r\n }\r\n
\r\n
\r\n {images.length?\r\n Object.values(images).map((imgFile,index)=>{\r\n return(\r\n
\r\n
\r\n
\r\n \r\n \r\n
\r\n
\r\n )\r\n })\r\n :(
)\r\n }\r\n \r\n
\r\n \r\n )\r\n}\r\n\r\nexport default UploaderImageMultipleBox","import React from 'react'\r\nimport Uploader from '../../Uploader'\r\nimport Icon from \"../../../../icon/CbmisIcon\"\r\n\r\nfunction UploaderImageAvatar(props) {\r\n const {images,setImages,gallery,camera,handelOpenCamera,maxSizeKB,maxFilesNumber,maxWidth,maxHeight,quality} = props\r\n\r\n return (\r\n \r\n \r\n {\r\n !camera?null:(\r\n
\r\n \r\n \r\n \r\n
\r\n )\r\n }\r\n
\r\n
\r\n {\r\n !gallery?null:(\r\n \r\n )\r\n }\r\n \r\n { images.length?\r\n
\r\n :\r\n
\r\n \r\n \r\n }\r\n
\r\n
\r\n \r\n )\r\n}\r\n\r\nexport default UploaderImageAvatar","import React from 'react'\r\nimport Uploader from '../../Uploader'\r\nimport Icon from \"../../../../icon/CbmisIcon\"\r\n\r\nfunction UploaderImageList(props) {\r\n const {images,setImages,gallery,camera,handelOpenCamera,handleDeleteFile,handleClear,handlePreview,maxSizeKB,maxFilesNumber,maxWidth,maxHeight,quality} = props\r\n\r\n return (\r\n \r\n \r\n
\r\n {\r\n Object.values(images).map((imgFile,index)=>{\r\n return(\r\n
\r\n
\r\n
\r\n
\r\n {imgFile.name}\r\n \r\n
\r\n
\r\n \r\n \r\n\r\n
\r\n
\r\n )\r\n })\r\n }\r\n
\r\n\r\n
\r\n {\r\n !Object.values(images).length?
:(\r\n
\r\n \r\n \r\n )\r\n }\r\n\r\n
\r\n {\r\n !gallery?null:(\r\n \r\n \r\n \r\n \r\n )\r\n }\r\n {\r\n !camera?null:(\r\n \r\n \r\n \r\n )\r\n }\r\n
\r\n
\r\n\r\n
\r\n \r\n )\r\n}\r\n\r\nexport default UploaderImageList","import React from 'react'\r\nimport Icon from \"../../../../icon/CbmisIcon\"\r\n\r\nfunction UploaderImageArea(props) {\r\n const {images,handelUploadOpen} = props\r\n\r\n return (\r\n \r\n \r\n
\r\n {images.length?\r\n
\r\n :\r\n
\r\n \r\n \r\n }\r\n
\r\n
\r\n \r\n )\r\n}\r\n\r\nexport default UploaderImageArea","import React from 'react'\r\nimport Typography from '../../../../material/dataDisplay/Typography/Typography'\r\nimport Button from '../../../../material/inputs/Button/Button'\r\nimport Grid from '../../../../material/layout/Grid/Grid'\r\nimport Icon from \"../../../../icon/CbmisIcon\"\r\n\r\n\r\nfunction UploaderImageButton(props) {\r\n const {images,handelUploadOpen,label,icon,mode,handlePreview} = props\r\n return (\r\n \r\n \r\n \r\n \r\n \r\n \r\n {\r\n images.length===1?(\r\n {images[0].name}}\r\n mode=\"link\"\r\n onClick={handlePreview(images[0],0)}\r\n />\r\n\r\n ):images.length>1?\r\n (\r\n {`${images.length} File Uploaded`}}\r\n mode=\"link\"\r\n onClick={handlePreview(images[0],0)}\r\n />\r\n ):null\r\n }\r\n \r\n \r\n \r\n )\r\n}\r\n\r\nexport default UploaderImageButton","\n import API from \"!../../../../node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js\";\n import domAPI from \"!../../../../node_modules/style-loader/dist/runtime/styleDomAPI.js\";\n import insertFn from \"!../../../../node_modules/style-loader/dist/runtime/insertBySelector.js\";\n import setAttributes from \"!../../../../node_modules/style-loader/dist/runtime/setAttributesWithoutAttributes.js\";\n import insertStyleElement from \"!../../../../node_modules/style-loader/dist/runtime/insertStyleElement.js\";\n import styleTagTransformFn from \"!../../../../node_modules/style-loader/dist/runtime/styleTagTransform.js\";\n import content, * as namedExport from \"!!../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[1].use[1]!./modal.css\";\n \n \n\nvar options = {};\n\noptions.styleTagTransform = styleTagTransformFn;\noptions.setAttributes = setAttributes;\n\n options.insert = insertFn.bind(null, \"head\");\n \noptions.domAPI = domAPI;\noptions.insertStyleElement = insertStyleElement;\n\nvar update = API(content, options);\n\n\n\nexport * from \"!!../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[1].use[1]!./modal.css\";\n export default content && content.locals ? content.locals : undefined;\n","import React, { useEffect, useState } from 'react'\r\nimport CamFeatureBtn from '../../cbmisCamera/cam-feature-btn/CamFeatureBtn'\r\nimport Modal from '../../../material/dataDisplay/Modal/Modal'\r\nimport ModalBody from '../../../material/dataDisplay/Modal/ModalBody'\r\nimport ModalHeader from '../../../material/dataDisplay/Modal/ModalHeader'\r\nimport Typography from '../../../material/dataDisplay/Typography/Typography'\r\nimport Grid from '../../../material/layout/Grid/Grid'\r\nimport Icon from \"../../../icon/CbmisIcon\"\r\n\r\nimport \"./modal.css\"\r\n\r\nfunction PreviewImage(props) {\r\n const {images,setImages,imgInfo,handelCloseModal,handleDeleteFile,blnChangeName}=props\r\n const {open,index}= imgInfo\r\n const [showIndex,setShowIndex] = useState(index || 0)\r\n\r\n function renameFile(originalFile, newName) {\r\n const newFiles = new File([originalFile], newName, {\r\n type: originalFile.type,\r\n lastModified: originalFile.lastModified,\r\n });\r\n return newFiles\r\n\r\n }\r\n\r\n const changeImageName=(event)=>{\r\n const index = event.target.id\r\n const newName = event.target.value\r\n var newArrayImages = images\r\n newArrayImages[index]= renameFile(newArrayImages[index],newName) || newArrayImages[index]\r\n setImages([...newArrayImages])\r\n }\r\n\r\n const handelClose=()=>{\r\n if(handelCloseModal){\r\n handelCloseModal()\r\n }\r\n }\r\n\r\n useEffect(() => {\r\n setShowIndex(index || 0)\r\n }, [index])\r\n \r\n return (\r\n \r\n \r\n \r\n {images[showIndex]?.name} \r\n \r\n \r\n {showIndex1?\r\n setShowIndex(showIndex+1)}\r\n color=\"#333\"\r\n />\r\n :null}\r\n\r\n {showIndex>0 && images.length>1?\r\n setShowIndex(showIndex-1)}\r\n color=\"#333\"\r\n />\r\n :null}\r\n \r\n \r\n \r\n \r\n \r\n\r\n \r\n \r\n {\r\n blnChangeName?(\r\n \r\n ):(\r\n {images[showIndex]?.name} \r\n )\r\n }\r\n\r\n \r\n \r\n\r\n \r\n \r\n \r\n \r\n size: {images[showIndex]?.size}\r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n )\r\n}\r\n\r\nexport default PreviewImage","import React from 'react'\r\nimport Modal from '../../../material/dataDisplay/Modal/Modal'\r\nimport ModalBody from '../../../material/dataDisplay/Modal/ModalBody'\r\nimport ModalHeader from '../../../material/dataDisplay/Modal/ModalHeader'\r\nimport Typography from '../../../material/dataDisplay/Typography/Typography'\r\nimport Grid from '../../../material/layout/Grid/Grid'\r\nimport Line from '../../../material/layout/Line/Line'\r\nimport Icon from '../../../icon/CbmisIcon'\r\nimport Uploader from '../Uploader'\r\nimport \"./modal.css\"\r\n\r\nfunction UploadModal(props) {\r\n const {open,setOpen,images,setImages,gallery,camera,handelOpenCamera,handleDeleteFile,handleClear,handlePreview,maxSizeKB,maxFilesNumber,maxWidth,maxHeight,quality}=props\r\n\r\n const handelClose =()=>{\r\n if(setOpen){\r\n setOpen(false)\r\n }\r\n }\r\n return (\r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n {\r\n !gallery?null:(\r\n \r\n \r\n \r\n \r\n \r\n \r\n )\r\n }\r\n {\r\n !camera?null:(\r\n \r\n \r\n \r\n \r\n \r\n )\r\n }\r\n \r\n \r\n \r\n {!images.length?(\r\n
\r\n ):Object.values(images).map((imgFile,index)=>{\r\n return(\r\n \r\n
\r\n
\r\n
\r\n {imgFile.name}\r\n \r\n
\r\n
\r\n \r\n \r\n\r\n
\r\n
\r\n )\r\n })\r\n }\r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n Total: {images.length}\r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n )\r\n}\r\n\r\nexport default UploadModal","import React, { useState } from 'react'\r\nimport \"./uploadImage.css\"\r\nimport UploaderImageBox from './mode/UploaderImageBox'\r\nimport UploaderImageMultipleBox from './mode/UploaderImageMultipleBox'\r\nimport UploaderImageAvatar from './mode/UploaderImageAvatar'\r\nimport UploaderImageList from './mode/UploaderImageList'\r\nimport UploaderImageArea from './mode/UploaderImageArea'\r\nimport UploaderImageButton from './mode/UploaderImageButton'\r\nimport PreviewImage from '../modalFileUploader/PreviewImage'\r\nimport UploadModal from '../modalFileUploader/UploadModal'\r\nimport Camera from '../../cbmisCamera/camera/Camera'\r\n\r\nfunction ImageUploader(props) {\r\n const {camera=true,gallery=true,mode,maxFilesNumber=1,maxSizeKB,blnChangeName,label,icon,maxWidth,maxHeight,quality=1,getImages,\r\n appPermissionState,handelChangePermission,lang,color,blnDownload}=props\r\n const [state, setState] = useState({\r\n files:[],\r\n cameraOpen:false,\r\n uploadOpen:false,\r\n imgInfo:{\r\n open:false,\r\n imageSelected:null,\r\n index:-1\r\n }\r\n })\r\n\r\n const handelOpenCamera=()=>{\r\n state.cameraOpen = true\r\n setState({...state})\r\n }\r\n const handelCloseCamera=(imageList)=>{\r\n state.cameraOpen = false\r\n state.files= imageList\r\n setState({...state})\r\n }\r\n\r\n const handleDeleteFile=(indexSelected)=>()=>{\r\n const filteredArray = state.files.filter(file=>state.files.indexOf(file) !==indexSelected)\r\n state.files = filteredArray\r\n setState({...state})\r\n }\r\n const handleClear=()=>{\r\n state.files = []\r\n setState({...state})\r\n }\r\n\r\n const handlePreview=(image,index)=>()=>{\r\n state.imgInfo = {\r\n open:true,\r\n imageSelected:image,\r\n index:index\r\n }\r\n setState({...state})\r\n }\r\n\r\n const handelUploadOpen=()=>{\r\n state.uploadOpen=true\r\n setState({...state})\r\n }\r\n const HandelCloseUpload=()=>{\r\n state.uploadOpen=false\r\n setState({...state})\r\n }\r\n const handelSetImage=(imageListFile)=>{\r\n if(imageListFile){\r\n state.files = imageListFile\r\n setState({...state})\r\n\r\n if(getImages){\r\n getImages(imageListFile)\r\n }\r\n }\r\n }\r\n const handelCloseModal=()=>{\r\n state.imgInfo = {\r\n open:false,\r\n imageSelected:\"\",\r\n index:-1\r\n }\r\n setState({...state})\r\n }\r\n\r\n\r\n const GetComponentJxs=()=>{\r\n switch (String(mode).toLowerCase()) {\r\n case \"box\":\r\n return(\r\n \r\n )\r\n case \"multiplebox\":\r\n return(\r\n \r\n )\r\n case \"avatar\":\r\n return(\r\n \r\n )\r\n case \"list\":\r\n return(\r\n \r\n )\r\n case \"area\":\r\n return(\r\n \r\n )\r\n\r\n case \"button\":\r\n return(\r\n \r\n )\r\n default:\r\n return(\r\n \r\n )\r\n }\r\n }\r\n\r\n return (\r\n \r\n \r\n\r\n \r\n \r\n\r\n \r\n\r\n \r\n )\r\n}\r\n\r\nexport default ImageUploader","\n import API from \"!../../../node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js\";\n import domAPI from \"!../../../node_modules/style-loader/dist/runtime/styleDomAPI.js\";\n import insertFn from \"!../../../node_modules/style-loader/dist/runtime/insertBySelector.js\";\n import setAttributes from \"!../../../node_modules/style-loader/dist/runtime/setAttributesWithoutAttributes.js\";\n import insertStyleElement from \"!../../../node_modules/style-loader/dist/runtime/insertStyleElement.js\";\n import styleTagTransformFn from \"!../../../node_modules/style-loader/dist/runtime/styleTagTransform.js\";\n import content, * as namedExport from \"!!../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[1].use[1]!./Chatbot.css\";\n \n \n\nvar options = {};\n\noptions.styleTagTransform = styleTagTransformFn;\noptions.setAttributes = setAttributes;\n\n options.insert = insertFn.bind(null, \"head\");\n \noptions.domAPI = domAPI;\noptions.insertStyleElement = insertStyleElement;\n\nvar update = API(content, options);\n\n\n\nexport * from \"!!../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[1].use[1]!./Chatbot.css\";\n export default content && content.locals ? content.locals : undefined;\n","\n import API from \"!../../../../node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js\";\n import domAPI from \"!../../../../node_modules/style-loader/dist/runtime/styleDomAPI.js\";\n import insertFn from \"!../../../../node_modules/style-loader/dist/runtime/insertBySelector.js\";\n import setAttributes from \"!../../../../node_modules/style-loader/dist/runtime/setAttributesWithoutAttributes.js\";\n import insertStyleElement from \"!../../../../node_modules/style-loader/dist/runtime/insertStyleElement.js\";\n import styleTagTransformFn from \"!../../../../node_modules/style-loader/dist/runtime/styleTagTransform.js\";\n import content, * as namedExport from \"!!../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[1].use[1]!./Avatar.css\";\n \n \n\nvar options = {};\n\noptions.styleTagTransform = styleTagTransformFn;\noptions.setAttributes = setAttributes;\n\n options.insert = insertFn.bind(null, \"head\");\n \noptions.domAPI = domAPI;\noptions.insertStyleElement = insertStyleElement;\n\nvar update = API(content, options);\n\n\n\nexport * from \"!!../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[1].use[1]!./Avatar.css\";\n export default content && content.locals ? content.locals : undefined;\n","import React, { useEffect, useRef } from \"react\";\r\nimport \"./Avatar.css\";\r\nimport \"../../../style/main.css\";\r\nimport * as componentsFunction from \"../../../helper/CbmisFunction\";\r\nimport useCheckScreenSize from \"../../../hook/useCheckScreenSize\";\r\nimport { setSxClassName } from \"../../../helper/convertJsCss\";\r\n\r\nconst Avatar = (props) => {\r\n const screenWidth = useCheckScreenSize();\r\n\r\n const { src, alt, color, mode, sx, hidden, disabled, dir, className, id, ...rest } = props;\r\n const getID = useRef(id || componentsFunction.randomName(\"Avatar\"));\r\n const styleRef = useRef({ strSxClassName: \"\", strSXComponentID: componentsFunction.randomName(\"cbmis-avatar\") });\r\n\r\n const getRestProps = () => {\r\n const newRest = componentsFunction.filterPaddingAndMargin(rest);\r\n return { ...newRest };\r\n };\r\n\r\n useEffect(() => {}, [src, alt, mode, hidden, disabled, dir, className, id]);\r\n\r\n\r\n\r\n useEffect(() => {\r\n if (sx) {\r\n setSxClassName(styleRef, styleRef.current.strSXComponentID, sx, \"cbmis-avatar\");\r\n }\r\n }, [sx, screenWidth]);\r\n\r\n const getAratarMode = () => {\r\n if (mode) return componentsFunction.getShapeReturnClassName(mode);\r\n else return componentsFunction.getShapeReturnClassName(\"circle\");\r\n };\r\n\r\n const avatarMode = useRef(getAratarMode());\r\n return (\r\n \r\n
\r\n
{props.children}
\r\n
\r\n
\r\n );\r\n};\r\n\r\nexport default Avatar;\r\n","import React from 'react'\r\nimport Avatar from \"../../../../material/dataDisplay/Avatar/Avatar\"\r\nimport Icon from \"../../../../icon/CbmisIcon\"\r\n\r\nexport default function AgentHeader({handelChatOpen,blnAgentImg=true,icon,iconColor,iconSize,avatarColor,avatarSize}) {\r\n return (\r\n \r\n \r\n \r\n {/*
ChatBot */}\r\n \r\n \r\n )\r\n}\r\n","import React from 'react'\r\nimport AgentHeader from '../agentHeader/AgentHeader'\r\n\r\nfunction Header(props) {\r\n const {blnAgentImg,icon,iconSize,iconColor,avatarColor,avatarSize}=props\r\n\r\n const handelChatOpen = ()=>{\r\n const messenger = document.querySelector(\".cbmis-messenger-main-container\")\r\n const close = document.querySelector(\".cbmis-messenger-close\")\r\n if(close){\r\n messenger.classList.remove(\"cbmis-messenger-close\")\r\n }else{\r\n messenger.classList.add(\"cbmis-messenger-close\")\r\n }\r\n const items = document.querySelector(\".items span\")\r\n items.style.opacity=0\r\n }\r\n\r\n const handelMenuClick=()=>{\r\n const items = document.querySelector(\".items span\")\r\n items.style.opacity=1\r\n }\r\n\r\n \r\n return (\r\n \r\n \r\n
\r\n \r\n {/* — \r\n */}\r\n ✕ \r\n \r\n
\r\n
...
\r\n
\r\n\r\n \r\n \r\n )\r\n}\r\n\r\nexport default Header","import React, { useEffect, useRef } from 'react'\r\n\r\nexport default function MessageBox(props) {\r\n const {conversion, setConversion,objChat,errorMsg,lastRebotMsg} =props\r\n const inputMsg = useRef(\"\")\r\n const inputMsgTemp = useRef(\"\")\r\n\r\n\r\n const handelSubmit=()=>{\r\n const inputMsgValue = inputMsg.current.value\r\n if(inputMsgValue){\r\n inputMsgTemp.current=inputMsgValue\r\n conversion.push({message:[{text:inputMsgValue}],isPersonal:true})\r\n inputMsg.current.value=\"\"\r\n conversion.push({message:[{text:\"\"}],isPersonal:false,isLoading:true}) //loading msg\r\n setConversion([...conversion])\r\n botMsg()\r\n\r\n \r\n }\r\n}\r\n\r\nconst handelPressEnter=(event)=>{\r\n if (event.key === \"Enter\") {\r\n event.preventDefault();\r\n handelSubmit()\r\n }\r\n}\r\n\r\nconst botMsg = ()=>{\r\n \r\n let newMessage= { \"message\": [{text:errorMsg}]}\r\n let newSelectedMsgInfo =null\r\n if(lastRebotMsg.current.blnNoSearch){\r\n newSelectedMsgInfo = objChat?.[lastRebotMsg.current?.nextIndex]\r\n\r\n }else if(lastRebotMsg.current.options){\r\n const nextIndex = lastRebotMsg.current.options.filter(item=>(item.keyWord).includes(inputMsgTemp.current))?.[0]?.[\"nextIndex\"]\r\n newSelectedMsgInfo = objChat?.[nextIndex]\r\n }else{\r\n const arrObjChat = Object.values(objChat)\r\n newSelectedMsgInfo = arrObjChat?.filter(item=>(item.keyWord).includes(inputMsgTemp.current))?.[0]\r\n }\r\n\r\n if(newSelectedMsgInfo){\r\n newMessage= newSelectedMsgInfo\r\n }\r\n\r\n conversion.pop()\r\n conversion.push({...newMessage,isPersonal:false,isLoading:false})\r\n lastRebotMsg.current={...newMessage,isPersonal:false,isLoading:false}\r\n setConversion([...conversion])\r\n}\r\n\r\n const handelOptionSelect=(option)=>()=>{\r\n conversion.push({message:[{text:option.label}],options:[],isPersonal:true,isLoading:false})\r\n const newMessage= {...objChat[option.nextIndex],isPersonal:false,isLoading:false}\r\n conversion.push(newMessage)\r\n lastRebotMsg.current=newMessage\r\n setConversion([...conversion])\r\n\r\n }\r\n\r\n useEffect(() => {\r\n var chatMessages = document.querySelector(\".cbmis-chat-messages .cbmis-chat-messages-content\");\r\n chatMessages.scrollTop = chatMessages.scrollHeight;\r\n }, [conversion])\r\n\r\n return (\r\n \r\n \r\n {\r\n conversion[conversion.length-1]?.options?.map((option,index)=>{\r\n return(\r\n \r\n {option.label}\r\n \r\n )\r\n })\r\n }\r\n
\r\n\r\n \r\n \r\n Send \r\n
\r\n \r\n )\r\n}\r\n","import React, { useEffect, useRef } from 'react'\r\n\r\nfunction Message(props) {\r\n const {messageInfo} = props\r\n\r\n const getTime=()=>{\r\n const d = new Date();\r\n let hour = d.getHours();\r\n let minutes = d.getMinutes()\r\n\r\n hour = hour<10?`0${hour}`:hour;\r\n minutes = minutes<10?`0${minutes}`:minutes;\r\n return `${hour}:${minutes}`\r\n }\r\n useEffect(() => {\r\n }, [messageInfo])\r\n\r\n const getIsMsgPersonal=()=>{\r\n if(messageInfo?.isPersonal){\r\n return \"cbmis-chat-message-personal\"\r\n }else{\r\n return \"\"\r\n }\r\n }\r\n \r\n const getIsLoading=()=>{\r\n if(messageInfo?.isLoading){\r\n return \"cbmis-chat-msg-loading\"\r\n }else{\r\n return \"\"\r\n }\r\n}\r\n return (\r\n \r\n messageInfo.message.map((msg,index)=>{\r\n return(\r\n \r\n \r\n {msg?.text}\r\n {/*
\r\n
{!getIsLoading() ? getTime():\"\"}
\r\n
✓
\r\n
✓
\r\n
*/}\r\n
\r\n {\r\n msg?.image?(\r\n \r\n
\r\n
\r\n ):null\r\n }\r\n \r\n )\r\n }\r\n )\r\n \r\n )\r\n}\r\n\r\nexport default Message","import React, { useEffect, useRef, useState } from 'react'\r\nimport './Chatbot.css'\r\n// import chat from \"./data.json\"\r\n\r\nimport Header from './components/hrader/Header'\r\nimport MessageBox from './components/messageBox/MessageBox'\r\nimport Message from './components/message/Message'\r\n\r\nfunction ChatBot(props) {\r\n const {chat={},errorMsg=\"Please, try again later.\",\r\n mode,positionHorizontal,positionVertical,blnAgentImg=true,icon,iconColor,iconSize,avatarColor,avatarSize\r\n } =props\r\n const [conversion, setConversion] = useState([])\r\n const lastRebotMsg = useRef(\"\")\r\n\r\n\r\n useEffect(() => {\r\n const newConversion = []\r\n if(!chat?.[\"root\"]){\r\n chat[\"root\"] = {\r\n \"message\": [],\r\n \"options\":[],\r\n \"keyWord\":[],\r\n \"nextIndex\":3\r\n }\r\n }\r\n chat[\"root\"].isPersonal=false\r\n lastRebotMsg.current=chat[\"root\"]\r\n newConversion[0]=chat[\"root\"]\r\n setConversion(newConversion)\r\n }, [chat])\r\n\r\n const getMode=()=>{\r\n switch (String(mode).toLowerCase()) {\r\n case \"full\":\r\n return \"cbmis-messenger-container-full\";\r\n default:\r\n return \"\";\r\n }\r\n }\r\n\r\n \r\n const getPositionHorizontal=()=>{\r\n switch (String(positionHorizontal).toLowerCase()) {\r\n case \"right\":\r\n return \"cbmis-messenger-position-horizontal-right\";\r\n default:\r\n return \"cbmis-messenger-position-horizontal-left\";\r\n }\r\n }\r\n const getPositionVertical=()=>{\r\n switch (String(positionVertical).toLowerCase()) {\r\n case \"bottom\":\r\n return \"cbmis-messenger-position-vertical-bottom\";\r\n default:\r\n return \"cbmis-messenger-position-vertical-top\";\r\n }\r\n }\r\n return (\r\n \r\n
\r\n \r\n \r\n
\r\n
\r\n {\r\n conversion.map((msg,index)=>{\r\n return(\r\n \r\n \r\n \r\n )\r\n })\r\n }\r\n
\r\n
\r\n
\r\n \r\n \r\n
\r\n )\r\n}\r\n\r\nexport default ChatBot","\n import API from \"!../../../node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js\";\n import domAPI from \"!../../../node_modules/style-loader/dist/runtime/styleDomAPI.js\";\n import insertFn from \"!../../../node_modules/style-loader/dist/runtime/insertBySelector.js\";\n import setAttributes from \"!../../../node_modules/style-loader/dist/runtime/setAttributesWithoutAttributes.js\";\n import insertStyleElement from \"!../../../node_modules/style-loader/dist/runtime/insertStyleElement.js\";\n import styleTagTransformFn from \"!../../../node_modules/style-loader/dist/runtime/styleTagTransform.js\";\n import content, * as namedExport from \"!!../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[1].use[1]!./CbmisVoiceRecorder.css\";\n \n \n\nvar options = {};\n\noptions.styleTagTransform = styleTagTransformFn;\noptions.setAttributes = setAttributes;\n\n options.insert = insertFn.bind(null, \"head\");\n \noptions.domAPI = domAPI;\noptions.insertStyleElement = insertStyleElement;\n\nvar update = API(content, options);\n\n\n\nexport * from \"!!../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[1].use[1]!./CbmisVoiceRecorder.css\";\n export default content && content.locals ? content.locals : undefined;\n","import { useEffect, useState } from \"react\";\r\nimport usePermissions from \"../CbmisPermissions/usePermissions\"\r\nimport * as Alert from \"../../material/feedback/Alert/Alert\"\r\n// import * as Confirmation from \"../../material/feedback/Confirmation/Confirmation\"\r\n\r\n\r\nconst useRecorder = (appPermissionState) => {\r\n const [audioURL, setAudioURL] = useState(\"\");\r\n const [isRecording, setIsRecording] = useState(false);\r\n const [recorder, setRecorder] = useState(null);\r\n const permissions = usePermissions(appPermissionState)\r\n\r\n useEffect(() => {\r\n // Lazily obtain recorder first time we're recording.\r\n if (recorder === null) {\r\n if (isRecording) {\r\n requestRecorder().then(setRecorder, console.error);\r\n }\r\n return;\r\n }\r\n\r\n // Manage recorder state.\r\n if (isRecording) {\r\n recorder.start();\r\n } else {\r\n recorder.stop();\r\n }\r\n\r\n // Obtain the audio when ready.\r\n const handleData = e => {\r\n setAudioURL(URL.createObjectURL(e.data));\r\n };\r\n\r\n recorder.addEventListener(\"dataavailable\", handleData);\r\n return () => recorder.removeEventListener(\"dataavailable\", handleData);\r\n }, [recorder, isRecording]);\r\n\r\n const startRecording = () => {\r\n if(appPermissionState){\r\n permissions.checkPermission(\"microphonePermission\")\r\n if(appPermissionState.microphonePermission.user && appPermissionState.microphonePermission.user){\r\n setIsRecording(true);\r\n }else{\r\n Alert.viewAlert(\"Please go to the permission page and turn on the microphone\")\r\n }\r\n }else{\r\n setIsRecording(true);\r\n }\r\n };\r\n\r\n const stopRecording = () => {\r\n setIsRecording(false);\r\n };\r\n\r\n const deleteRecording = () => {\r\n // if(audioURL){\r\n // Confirmation(\"Are you sure to delete this record?\",()=>{\r\n setAudioURL(\"\")\r\n // })\r\n // }\r\n\r\n setAudioURL(\"\")\r\n\r\n };\r\n\r\n \r\n return {audioURL, isRecording, startRecording, stopRecording, deleteRecording};\r\n};\r\n\r\nasync function requestRecorder() {\r\n const stream = await navigator.mediaDevices.getUserMedia({ audio: true });\r\n return new MediaRecorder(stream);\r\n}\r\n\r\n\r\nexport default useRecorder;\r\n","import React, { useEffect } from 'react'\r\nimport \"./CbmisVoiceRecorder.css\"\r\nimport useRecorder from './useRecorder';\r\nimport Grid from '../../material/layout/Grid/Grid';\r\nimport Icon from '../../icon/CbmisIcon';\r\n\r\nfunction CbmisVoiceRecorder({appPermissionState,getAudioURL}) {\r\n let {audioURL, isRecording, startRecording, stopRecording,deleteRecording}= useRecorder(appPermissionState);\r\n\r\n const handelClicked=()=>{\r\n if(!isRecording){\r\n startRecording()\r\n }else{\r\n stopRecording()\r\n deleteRecording()\r\n }\r\n }\r\n\r\n useEffect(() => {\r\n if(audioURL && getAudioURL){\r\n getAudioURL(audioURL)\r\n }\r\n}, [audioURL,getAudioURL])\r\n\r\n\r\n\r\n return (\r\n \r\n \r\n {audioURL?(\r\n
\r\n \r\n \r\n \r\n ):(\r\n
\r\n \r\n \r\n )}\r\n \r\n
\r\n \r\n )\r\n}\r\n\r\nexport default CbmisVoiceRecorder","\n import API from \"!../../../../node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js\";\n import domAPI from \"!../../../../node_modules/style-loader/dist/runtime/styleDomAPI.js\";\n import insertFn from \"!../../../../node_modules/style-loader/dist/runtime/insertBySelector.js\";\n import setAttributes from \"!../../../../node_modules/style-loader/dist/runtime/setAttributesWithoutAttributes.js\";\n import insertStyleElement from \"!../../../../node_modules/style-loader/dist/runtime/insertStyleElement.js\";\n import styleTagTransformFn from \"!../../../../node_modules/style-loader/dist/runtime/styleTagTransform.js\";\n import content, * as namedExport from \"!!../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[1].use[1]!./Chip.css\";\n \n \n\nvar options = {};\n\noptions.styleTagTransform = styleTagTransformFn;\noptions.setAttributes = setAttributes;\n\n options.insert = insertFn.bind(null, \"head\");\n \noptions.domAPI = domAPI;\noptions.insertStyleElement = insertStyleElement;\n\nvar update = API(content, options);\n\n\n\nexport * from \"!!../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[1].use[1]!./Chip.css\";\n export default content && content.locals ? content.locals : undefined;\n","import React, { useEffect, useRef } from \"react\";\r\nimport \"./Chip.css\";\r\nimport \"../../../style/main.css\";\r\nimport * as componentsFunction from \"../../../helper/CbmisFunction\";\r\nimport useCheckScreenSize from \"../../../hook/useCheckScreenSize\";\r\nimport { setSxClassName } from \"../../../helper/convertJsCss\";\r\nimport Avatar from \"../Avatar/Avatar\";\r\n\r\nconst Chip = (props) => {\r\n const { label, mode, size, color, avatar, endAvatar, sx, hidden, disabled, dir, className, id, ...rest } = props;\r\n\r\n const screenWidth = useCheckScreenSize();\r\n\r\n const getID = useRef(id || componentsFunction.randomName(\"Chip\"));\r\n const styleRef = useRef({ strSxClassName: \"\" });\r\n\r\n useEffect(() => {}, [label, size, avatar, endAvatar, hidden, disabled, dir, className, id]);\r\n\r\n useEffect(() => {\r\n const chipStyle = String(mode).toLowerCase();\r\n setSxClassName(\r\n styleRef,\r\n getID.current,\r\n {\r\n ...(sx ? { ...sx } : {}),\r\n ...(chipStyle !== \"outlined\"\r\n ? { background: `${color} !important` }\r\n : {\r\n borderColor: `\"var(--cbmis-whait)\" !important`,\r\n color: `${color} !important`,\r\n background: `transparent !important`,\r\n }),\r\n },\r\n \"cbmis-chip\"\r\n );\r\n }, [sx, screenWidth, color, mode]);\r\n\r\n const getRestProps = () => {\r\n const newRest = componentsFunction.filterPaddingAndMargin(rest);\r\n return { ...newRest };\r\n };\r\n\r\n const getChipStyle = () => {\r\n const chipStyle = String(mode).toLowerCase();\r\n switch (chipStyle) {\r\n case \"outlined\":\r\n return \"cbmis-chip-outlined\";\r\n default:\r\n return \"cbmis-chip-filled\";\r\n }\r\n };\r\n\r\n const getChipSize = () => {\r\n const chipSize = String(size).toLowerCase();\r\n switch (chipSize) {\r\n case \"sm\":\r\n return { chipSize: \"cbmis-chip-size-sm\", iconSize: \"15px\" };\r\n default:\r\n return { chipSize: \"cbmis-chip-size-md\", iconSize: \"20px\" };\r\n }\r\n };\r\n\r\n return (\r\n \r\n {avatar ? (\r\n
\r\n {avatar.props.children}\r\n \r\n ) : (\r\n \"\"\r\n )}\r\n
{label}
\r\n {endAvatar ? (\r\n
\r\n {endAvatar.props.children}\r\n \r\n ) : (\r\n \"\"\r\n )}\r\n
\r\n );\r\n};\r\n\r\nexport default Chip;\r\n","\n import API from \"!../../../../node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js\";\n import domAPI from \"!../../../../node_modules/style-loader/dist/runtime/styleDomAPI.js\";\n import insertFn from \"!../../../../node_modules/style-loader/dist/runtime/insertBySelector.js\";\n import setAttributes from \"!../../../../node_modules/style-loader/dist/runtime/setAttributesWithoutAttributes.js\";\n import insertStyleElement from \"!../../../../node_modules/style-loader/dist/runtime/insertStyleElement.js\";\n import styleTagTransformFn from \"!../../../../node_modules/style-loader/dist/runtime/styleTagTransform.js\";\n import content, * as namedExport from \"!!../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[1].use[1]!./Counter.css\";\n \n \n\nvar options = {};\n\noptions.styleTagTransform = styleTagTransformFn;\noptions.setAttributes = setAttributes;\n\n options.insert = insertFn.bind(null, \"head\");\n \noptions.domAPI = domAPI;\noptions.insertStyleElement = insertStyleElement;\n\nvar update = API(content, options);\n\n\n\nexport * from \"!!../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[1].use[1]!./Counter.css\";\n export default content && content.locals ? content.locals : undefined;\n","import React, { useEffect, useRef, useState } from \"react\";\r\nimport \"./Counter.css\";\r\nimport \"../../../style/main.css\";\r\nimport * as componentsFunction from \"../../../helper/CbmisFunction\";\r\nimport useCheckScreenSize from \"../../../hook/useCheckScreenSize\";\r\nimport { setSxClassName } from \"../../../helper/convertJsCss\";\r\n\r\nfunction Counter(props) {\r\n const { count, sx, hidden, disabled, dir, className, id, ...rest } = props;\r\n const screenWidth = useCheckScreenSize();\r\n const getID = useRef(id || componentsFunction.randomName(\"Counter\"));\r\n const styleRef = useRef({ strSxClassName: \"\" });\r\n\r\n const maximum = parseInt(count) || 100;\r\n const [counterState, setCounterState] = useState(0);\r\n\r\n const counter = () => {\r\n for (let i = 0; i <= maximum; i++) {\r\n setTimeout(() => {\r\n setCounterState(i);\r\n }, 1000);\r\n }\r\n };\r\n\r\n const getRestProps = () => {\r\n const newRest = componentsFunction.filterPaddingAndMargin(rest);\r\n return { ...newRest };\r\n };\r\n\r\n useEffect(() => {}, [hidden, disabled, dir, className, id]);\r\n\r\n useEffect(() => {\r\n return () => {\r\n counter();\r\n };\r\n }, [count]);\r\n\r\n useEffect(() => {\r\n if (sx) {\r\n setSxClassName(styleRef, getID.current, sx, \"cbmis-counter\");\r\n }\r\n }, [sx, screenWidth]);\r\n\r\n return (\r\n \r\n \r\n {counterState}\r\n
\r\n \r\n );\r\n}\r\n\r\nexport default Counter;\r\n","import React, { useEffect, useRef } from \"react\";\r\nimport \"./Modal.css\";\r\nimport \"../../../style/main.css\";\r\nimport * as componentsFunction from \"../../../helper/CbmisFunction\";\r\nimport useCheckScreenSize from \"../../../hook/useCheckScreenSize\";\r\nimport { setSxClassName } from \"../../../helper/convertJsCss\";\r\n\r\nconst ModalFooter = (props) => {\r\n const { sx, hidden, disabled, dir, className, id, ...rest } = props;\r\n const screenWidth = useCheckScreenSize();\r\n\r\n const getID = useRef(id || componentsFunction.randomName(\"ModalFooter\"));\r\n const styleRef = useRef({ strSxClassName: \"\" });\r\n\r\n useEffect(() => {}, [hidden, disabled, dir, className, id]);\r\n\r\n useEffect(() => {\r\n if (sx) {\r\n setSxClassName(styleRef, getID.current, sx, \"cbmis-modal-footer\");\r\n }\r\n }, [sx, screenWidth]);\r\n\r\n const getRestProps = () => {\r\n const newRest = componentsFunction.filterPaddingAndMargin(rest);\r\n return { ...newRest };\r\n };\r\n\r\n return (\r\n \r\n {props.children}\r\n
\r\n );\r\n};\r\n\r\nexport default ModalFooter;\r\n","\n import API from \"!../../../../node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js\";\n import domAPI from \"!../../../../node_modules/style-loader/dist/runtime/styleDomAPI.js\";\n import insertFn from \"!../../../../node_modules/style-loader/dist/runtime/insertBySelector.js\";\n import setAttributes from \"!../../../../node_modules/style-loader/dist/runtime/setAttributesWithoutAttributes.js\";\n import insertStyleElement from \"!../../../../node_modules/style-loader/dist/runtime/insertStyleElement.js\";\n import styleTagTransformFn from \"!../../../../node_modules/style-loader/dist/runtime/styleTagTransform.js\";\n import content, * as namedExport from \"!!../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[1].use[1]!./Tooltip.css\";\n \n \n\nvar options = {};\n\noptions.styleTagTransform = styleTagTransformFn;\noptions.setAttributes = setAttributes;\n\n options.insert = insertFn.bind(null, \"head\");\n \noptions.domAPI = domAPI;\noptions.insertStyleElement = insertStyleElement;\n\nvar update = API(content, options);\n\n\n\nexport * from \"!!../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[1].use[1]!./Tooltip.css\";\n export default content && content.locals ? content.locals : undefined;\n","import React, { useEffect, useRef } from \"react\";\r\nimport \"./Tooltip.css\";\r\nimport \"../../../style/main.css\";\r\nimport * as componentsFunction from \"../../../helper/CbmisFunction\";\r\nimport useCheckScreenSize from \"../../../hook/useCheckScreenSize\";\r\nimport { setSxClassName } from \"../../../helper/convertJsCss\";\r\n\r\nconst Tooltip = (props) => {\r\n const { title, position, mode, color, sx, hidden, disabled, dir, className, id, ...rest } = props;\r\n const screenWidth = useCheckScreenSize();\r\n\r\n const getID = useRef(id || componentsFunction.randomName(\"Tooltip\"));\r\n const styleRef = useRef({ strSxClassName: \"\", strSXComponentID: componentsFunction.randomName(\"cbmis-tooltip-text\") });\r\n\r\n const getRestProps = () => {\r\n const newRest = componentsFunction.filterPaddingAndMargin(rest);\r\n return { ...newRest };\r\n };\r\n\r\n useEffect(() => {}, [title, position, mode, hidden, disabled, dir, className, id]);\r\n\r\n useEffect(() => {\r\n if (sx || color) {\r\n setSxClassName(styleRef, styleRef.current.strSXComponentID, { ...(sx ? sx : {}), ...(color ? { background: `${color}` } : {}) }, \"cbmis-tooltip-text\");\r\n }\r\n }, [sx, screenWidth, color]);\r\n\r\n useEffect(() => {\r\n if (color && title) {\r\n document.documentElement.style.setProperty(\"--cbmis-tooltip-arrow-color\", componentsFunction.checkColorReturnValue(color));\r\n }\r\n }, [color]);\r\n\r\n const getPositionTooltip = () => {\r\n const getPosition = String(position).toLowerCase();\r\n const getStyle = String(mode).toLowerCase();\r\n if (getStyle === \"arrow\") {\r\n switch (getPosition) {\r\n case \"top\":\r\n return \"cbmis-tooltip-text-position-top-arrow\";\r\n case \"left\":\r\n return \"cbmis-tooltip-text-position-left-arrow\";\r\n case \"bottom\":\r\n return \"cbmis-tooltip-text-position-bottom-arrow\";\r\n case \"right\":\r\n return \"cbmis-tooltip-text-position-right-arrow\";\r\n default:\r\n return \"cbmis-tooltip-text-position-top-arrow\";\r\n }\r\n } else {\r\n switch (getPosition) {\r\n case \"top\":\r\n return \"cbmis-tooltip-text-position-top\";\r\n case \"left\":\r\n return \"cbmis-tooltip-text-position-left\";\r\n case \"bottom\":\r\n return \"cbmis-tooltip-text-position-bottom\";\r\n case \"right\":\r\n return \"cbmis-tooltip-text-position-right\";\r\n default:\r\n return \"cbmis-tooltip-text-position-top\";\r\n }\r\n }\r\n };\r\n\r\n const positionTooltip = useRef(getPositionTooltip());\r\n\r\n return (\r\n \r\n {title ? (\r\n
\r\n {title} \r\n
\r\n ) : (\r\n \"\"\r\n )}\r\n
\r\n );\r\n};\r\n\r\nexport default Tooltip;\r\n","\n import API from \"!../../../../node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js\";\n import domAPI from \"!../../../../node_modules/style-loader/dist/runtime/styleDomAPI.js\";\n import insertFn from \"!../../../../node_modules/style-loader/dist/runtime/insertBySelector.js\";\n import setAttributes from \"!../../../../node_modules/style-loader/dist/runtime/setAttributesWithoutAttributes.js\";\n import insertStyleElement from \"!../../../../node_modules/style-loader/dist/runtime/insertStyleElement.js\";\n import styleTagTransformFn from \"!../../../../node_modules/style-loader/dist/runtime/styleTagTransform.js\";\n import content, * as namedExport from \"!!../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[1].use[1]!./Table.css\";\n \n \n\nvar options = {};\n\noptions.styleTagTransform = styleTagTransformFn;\noptions.setAttributes = setAttributes;\n\n options.insert = insertFn.bind(null, \"head\");\n \noptions.domAPI = domAPI;\noptions.insertStyleElement = insertStyleElement;\n\nvar update = API(content, options);\n\n\n\nexport * from \"!!../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[1].use[1]!./Table.css\";\n export default content && content.locals ? content.locals : undefined;\n","import React, { useEffect, useRef } from \"react\";\r\nimport \"./Table.css\";\r\nimport \"../../../style/main.css\";\r\nimport * as componentsFunction from \"../../../helper/CbmisFunction\";\r\nimport useCheckScreenSize from \"../../../hook/useCheckScreenSize\";\r\nimport { setSxClassName } from \"../../../helper/convertJsCss\";\r\n\r\nfunction Table(props) {\r\n const { mobileMode, sx, hidden, disabled, dir, className, id, ...rest } = props;\r\n const screenWidth = useCheckScreenSize();\r\n\r\n const styleRef = useRef({ strSxClassName: \"\" });\r\n const getID = useRef(id || componentsFunction.randomName(\"Table\"));\r\n\r\n useEffect(() => {\r\n if (sx) {\r\n setSxClassName(styleRef, getID.current, sx, \"cbmis-table-contenter\");\r\n }\r\n }, [sx, screenWidth]);\r\n\r\n const getRestProps = () => {\r\n const newRest = componentsFunction.filterPaddingAndMargin(rest);\r\n return { ...newRest };\r\n };\r\n\r\n const getTableClassName = () => {\r\n if ((mobileMode === false || mobileMode === \"off\") && typeof mobileMode !== \"undefined\") {\r\n return \"cbmis-mobile-mod-off-contenter\";\r\n } else {\r\n return \"cbmis-table-contenter\";\r\n }\r\n };\r\n\r\n return (\r\n \r\n );\r\n}\r\n\r\nexport default Table;\r\n","import React, { useEffect, useRef } from \"react\";\r\nimport \"./Table.css\";\r\nimport \"../../../style/main.css\";\r\nimport * as componentsFunction from \"../../../helper/CbmisFunction\";\r\nimport useCheckScreenSize from \"../../../hook/useCheckScreenSize\";\r\nimport { setSxClassName } from \"../../../helper/convertJsCss\";\r\n\r\nfunction TableHead(props) {\r\n const { sx, hidden, disabled, dir, className, id, ...rest } = props;\r\n const screenWidth = useCheckScreenSize();\r\n\r\n const getID = useRef(id || componentsFunction.randomName(\"TableHead\"));\r\n const styleRef = useRef({ strSxClassName: \"\" });\r\n\r\n useEffect(() => {\r\n if (sx) {\r\n setSxClassName(styleRef, getID.current, sx, \"cbmis-table-head\");\r\n }\r\n }, [sx, screenWidth]);\r\n\r\n const getRestProps = () => {\r\n const newRest = componentsFunction.filterPaddingAndMargin(rest);\r\n return { ...newRest };\r\n };\r\n\r\n return (\r\n \r\n {props.children}\r\n \r\n );\r\n}\r\n\r\nexport default TableHead;\r\n","import React, { useEffect, useRef } from \"react\";\r\nimport \"./Table.css\";\r\nimport \"../../../style/main.css\";\r\nimport * as componentsFunction from \"../../../helper/CbmisFunction\";\r\nimport useCheckScreenSize from \"../../../hook/useCheckScreenSize\";\r\nimport { setSxClassName } from \"../../../helper/convertJsCss\";\r\n\r\nfunction TableBody(props) {\r\n const { sx, hidden, disabled, dir, className, id, ...rest } = props;\r\n const screenWidth = useCheckScreenSize();\r\n\r\n const getID = useRef(id || componentsFunction.randomName(\"TableBody\"));\r\n const styleRef = useRef({ strSxClassName: \"\" });\r\n\r\n useEffect(() => {}, [hidden, disabled, dir, className, id]);\r\n\r\n useEffect(() => {\r\n if (sx) {\r\n setSxClassName(styleRef, getID.current, sx, \"cbmis-table-cell\");\r\n }\r\n }, [sx, screenWidth]);\r\n\r\n const getRestProps = () => {\r\n const newRest = componentsFunction.filterPaddingAndMargin(rest);\r\n return { ...newRest };\r\n };\r\n\r\n return (\r\n \r\n {props.children}\r\n \r\n );\r\n}\r\n\r\nexport default TableBody;\r\n","import React, { useEffect, useRef } from \"react\";\r\nimport \"./Table.css\";\r\nimport \"../../../style/main.css\";\r\nimport * as componentsFunction from \"../../../helper/CbmisFunction\";\r\nimport useCheckScreenSize from \"../../../hook/useCheckScreenSize\";\r\nimport { setSxClassName } from \"../../../helper/convertJsCss\";\r\n\r\nfunction TableFooter(props) {\r\n const { sx, hidden, disabled, dir, className, id, ...rest } = props;\r\n const screenWidth = useCheckScreenSize();\r\n\r\n const getID = useRef(id || componentsFunction.randomName(\"TableFooter\"));\r\n const styleRef = useRef({ strSxClassName: \"\" });\r\n\r\n useEffect(() => {\r\n if (sx) {\r\n setSxClassName(styleRef, getID.current, sx, \"cbmis-table-footer\");\r\n }\r\n }, [sx, screenWidth]);\r\n\r\n const getRestProps = () => {\r\n const newRest = componentsFunction.filterPaddingAndMargin(rest);\r\n return { ...newRest };\r\n };\r\n\r\n return (\r\n \r\n {props.children}\r\n \r\n );\r\n}\r\n\r\nexport default TableFooter;\r\n","import React, { useEffect, useRef } from \"react\";\r\nimport \"./Table.css\";\r\nimport \"../../../style/main.css\";\r\nimport * as componentsFunction from \"../../../helper/CbmisFunction\";\r\nimport useCheckScreenSize from \"../../../hook/useCheckScreenSize\";\r\nimport { setSxClassName } from \"../../../helper/convertJsCss\";\r\n\r\nfunction TableRow(props) {\r\n const { sx, hidden, disabled, dir, className, id, ...rest } = props;\r\n const screenWidth = useCheckScreenSize();\r\n\r\n const getID = useRef(id || componentsFunction.randomName(\"TableRow\"));\r\n const styleRef = useRef({ strSxClassName: \"\" });\r\n\r\n useEffect(() => {\r\n if (sx) {\r\n setSxClassName(styleRef, getID.current, sx, \"cbmis-table-row\");\r\n }\r\n }, [sx, screenWidth]);\r\n\r\n const getRestProps = () => {\r\n const newRest = componentsFunction.filterPaddingAndMargin(rest);\r\n return { ...newRest };\r\n };\r\n\r\n return (\r\n \r\n {props.children}\r\n \r\n );\r\n}\r\n\r\nexport default TableRow;\r\n","import React, { useEffect, useRef } from \"react\";\r\nimport \"./Table.css\";\r\nimport \"../../../style/main.css\";\r\nimport * as componentsFunction from \"../../../helper/CbmisFunction\";\r\nimport useCheckScreenSize from \"../../../hook/useCheckScreenSize\";\r\nimport { setSxClassName } from \"../../../helper/convertJsCss\";\r\n\r\nfunction TableCell(props) {\r\n const { headLabel, rowSpan, colSpan, sx, hidden, disabled, dir, className, id, ...rest } = props;\r\n const screenWidth = useCheckScreenSize();\r\n\r\n const getID = useRef(id || componentsFunction.randomName(\"TableCell\"));\r\n const styleRef = useRef({ strSxClassName: \"\" });\r\n\r\n const getRestProps = () => {\r\n const newRest = componentsFunction.filterPaddingAndMargin(rest);\r\n return { ...newRest };\r\n };\r\n\r\n useEffect(() => {}, [headLabel, rowSpan, colSpan, hidden, disabled, dir, className, id]);\r\n\r\n useEffect(() => {\r\n if (sx) {\r\n setSxClassName(styleRef, getID.current, sx, \"cbmis-table-cell\");\r\n }\r\n }, [sx, screenWidth]);\r\n\r\n return (\r\n \r\n {props.children}\r\n \r\n );\r\n}\r\n\r\nexport default TableCell;\r\n","\n import API from \"!../../../../node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js\";\n import domAPI from \"!../../../../node_modules/style-loader/dist/runtime/styleDomAPI.js\";\n import insertFn from \"!../../../../node_modules/style-loader/dist/runtime/insertBySelector.js\";\n import setAttributes from \"!../../../../node_modules/style-loader/dist/runtime/setAttributesWithoutAttributes.js\";\n import insertStyleElement from \"!../../../../node_modules/style-loader/dist/runtime/insertStyleElement.js\";\n import styleTagTransformFn from \"!../../../../node_modules/style-loader/dist/runtime/styleTagTransform.js\";\n import content, * as namedExport from \"!!../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[1].use[1]!./VideoPlayer.css\";\n \n \n\nvar options = {};\n\noptions.styleTagTransform = styleTagTransformFn;\noptions.setAttributes = setAttributes;\n\n options.insert = insertFn.bind(null, \"head\");\n \noptions.domAPI = domAPI;\noptions.insertStyleElement = insertStyleElement;\n\nvar update = API(content, options);\n\n\n\nexport * from \"!!../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[1].use[1]!./VideoPlayer.css\";\n export default content && content.locals ? content.locals : undefined;\n","import React, { useEffect, useRef } from \"react\";\r\nimport \"./VideoPlayer.css\";\r\nimport \"../../../style/main.css\";\r\nimport * as componentsFunction from \"../../../helper/CbmisFunction\";\r\nimport useCheckScreenSize from \"../../../hook/useCheckScreenSize\";\r\nimport { setSxClassName } from \"../../../helper/convertJsCss\";\r\n\r\nfunction VideoPlayer(props) {\r\n const { src, imageSrc, sx, hidden, disabled, dir, className, id, ...rest } = props;\r\n const screenWidth = useCheckScreenSize();\r\n\r\n const getID = useRef(id || componentsFunction.randomName(\"VideoPlayer\"));\r\n const styleRef = useRef({ strSxClassName: \"\", strSXComponentID: componentsFunction.randomName(\".cbmis-video-container\") });\r\n\r\n useEffect(() => {}, [src, imageSrc, id, sx, hidden, disabled, dir, className]);\r\n\r\n useEffect(() => {\r\n if (sx) {\r\n setSxClassName(styleRef, styleRef.current.strSXComponentID, sx, \"cbmis-video-container\");\r\n }\r\n }, [sx, screenWidth]);\r\n\r\n const getRestProps = () => {\r\n const newRest = componentsFunction.filterPaddingAndMargin(rest);\r\n return { ...newRest };\r\n };\r\n\r\n return (\r\n \r\n \r\n \r\n \r\n \r\n
\r\n \r\n );\r\n}\r\n\r\nexport default VideoPlayer;\r\n","\n import API from \"!../../../../../../node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js\";\n import domAPI from \"!../../../../../../node_modules/style-loader/dist/runtime/styleDomAPI.js\";\n import insertFn from \"!../../../../../../node_modules/style-loader/dist/runtime/insertBySelector.js\";\n import setAttributes from \"!../../../../../../node_modules/style-loader/dist/runtime/setAttributesWithoutAttributes.js\";\n import insertStyleElement from \"!../../../../../../node_modules/style-loader/dist/runtime/insertStyleElement.js\";\n import styleTagTransformFn from \"!../../../../../../node_modules/style-loader/dist/runtime/styleTagTransform.js\";\n import content, * as namedExport from \"!!../../../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[1].use[1]!./Heatmap.css\";\n \n \n\nvar options = {};\n\noptions.styleTagTransform = styleTagTransformFn;\noptions.setAttributes = setAttributes;\n\n options.insert = insertFn.bind(null, \"head\");\n \noptions.domAPI = domAPI;\noptions.insertStyleElement = insertStyleElement;\n\nvar update = API(content, options);\n\n\n\nexport * from \"!!../../../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[1].use[1]!./Heatmap.css\";\n export default content && content.locals ? content.locals : undefined;\n","import React from 'react';\r\nimport './Heatmap.css';\r\n\r\n/**\r\n * HeatMap component displays a heatmap based on the data provided.\r\n * @param {Object} objData - An object containing xLabels, yLabels, and data for the heatmap.\r\n * @param {Object} colorMapping - An object mapping values to colors.\r\n * @param {boolean} showXLabel - A flag to show x labels in cells if true.\r\n * @param {boolean} showyLabel - A flag to show y labels in cells if true and showXLabel is false.\r\n * @param {string} color - A color string to be used when colorMapping is not provided.\r\n * @param {boolean} showValue - A flag to show values inside the cells if true.\r\n */\r\nconst HeatMap = ({ objData, colorMapping, showXLabel, showyLabel, color, showValue = true }) => {\r\n\tconst { xLabels, yLabels, data } = objData;\r\n\tconst reversedYLabels = [...yLabels].reverse();\r\n\r\n\tconst maxData = Math.max(...data.map((item) => item.value || 0));\r\n\r\n\tconst renderTableCell = (xLabel, yLabel, cellIndex) => {\r\n\t\tconst cell = data.find((item) => item.x === xLabel && item.y === yLabel);\r\n\t\tconst value =\r\n\t\t\tshowXLabel && cell ? xLabel : showyLabel && cell ? yLabel : cell?.value ? cell?.value : xLabel ? cell?.x : null;\r\n\t\tconst backgroundColor = color ? `rgba(${color},${value / maxData})` : undefined;\r\n\t\tlet cellColor;\r\n\t\tif (colorMapping?.[value] !== undefined) {\r\n\t\t\tcellColor = colorMapping[value];\r\n\t\t} else {\r\n\t\t\tconst range = colorMapping?.ranges.find((r) => typeof value === 'number' && value > r.min && value <= r.max);\r\n\t\t\tcellColor = range ? range.color : backgroundColor;\r\n\t\t}\r\n\r\n\t\treturn (\r\n\t\t\t\r\n\t\t\t\t{showValue && value}\r\n\t\t\t \r\n\t\t);\r\n\t};\r\n\r\n\tconst renderTableRow = (yLabel, rowIndex) => (\r\n\t\t\r\n\t\t\t{yLabel} \r\n\t\t\t{xLabels.map((xLabel, cellIndex) => renderTableCell(xLabel, yLabel, cellIndex))}\r\n\t\t \r\n\t);\r\n\r\n\tconst renderFooterRow = () => (\r\n\t\t\r\n\t\t\t \r\n\t\t\t{xLabels.map((label, index) => (\r\n\t\t\t\t{label} \r\n\t\t\t))}\r\n\t\t \r\n\t);\r\n\r\n\treturn (\r\n\t\t\r\n\t\t\t
\r\n\t\t\t\t{reversedYLabels.map((yLabel, rowIndex) => renderTableRow(yLabel, rowIndex))} \r\n\t\t\t\t{renderFooterRow()} \r\n\t\t\t
\r\n\t\t
\r\n\t);\r\n};\r\n\r\nexport default HeatMap;\r\n","\n import API from \"!../../../../../../node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js\";\n import domAPI from \"!../../../../../../node_modules/style-loader/dist/runtime/styleDomAPI.js\";\n import insertFn from \"!../../../../../../node_modules/style-loader/dist/runtime/insertBySelector.js\";\n import setAttributes from \"!../../../../../../node_modules/style-loader/dist/runtime/setAttributesWithoutAttributes.js\";\n import insertStyleElement from \"!../../../../../../node_modules/style-loader/dist/runtime/insertStyleElement.js\";\n import styleTagTransformFn from \"!../../../../../../node_modules/style-loader/dist/runtime/styleTagTransform.js\";\n import content, * as namedExport from \"!!../../../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[1].use[1]!./BulletChart.css\";\n \n \n\nvar options = {};\n\noptions.styleTagTransform = styleTagTransformFn;\noptions.setAttributes = setAttributes;\n\n options.insert = insertFn.bind(null, \"head\");\n \noptions.domAPI = domAPI;\noptions.insertStyleElement = insertStyleElement;\n\nvar update = API(content, options);\n\n\n\nexport * from \"!!../../../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[1].use[1]!./BulletChart.css\";\n export default content && content.locals ? content.locals : undefined;\n","import React from 'react';\r\nimport './BulletChart.css';\r\n\r\nconst BulletChart = ({ objData, colorMapping, showXLabel, showyLabel, showValue = true }) => {\r\n\tconst { xLabels, yLabels, data } = objData;\r\n\tconst reversedYLabels = [...yLabels].reverse();\r\n\r\n\tconst renderTableCell = (xLabel, yLabel, cellIndex) => {\r\n\t\tconst cell = data.find((item) => item.x === xLabel && item.y === yLabel);\r\n\t\tconst value =\r\n\t\t\tshowXLabel && cell ? xLabel : showyLabel && cell ? yLabel : cell?.value ? cell?.value : xLabel ? cell?.x : null;\r\n\t\tconst bulletColor = colorMapping?.[value] !== undefined ? colorMapping[value] : 'black';\r\n\r\n\t\treturn (\r\n\t\t\t\r\n\t\t\t\t\r\n\t\t\t\t\t
{showValue && value}
\r\n\t\t\t\t\t
\r\n\t\t\t\t\t\t{cell && (\r\n\t\t\t\t\t\t\t\r\n\t\t\t\t\t\t\t\t \r\n\t\t\t\t\t\t\t \r\n\t\t\t\t\t\t)}\r\n\t\t\t\t\t
\r\n\t\t\t\t
\r\n\t\t\t \r\n\t\t);\r\n\t};\r\n\r\n\tconst renderTableRow = (yLabel, rowIndex) => (\r\n\t\t\r\n\t\t\t{yLabel} \r\n\t\t\t{xLabels.map((xLabel, cellIndex) => renderTableCell(xLabel, yLabel, cellIndex))}\r\n\t\t \r\n\t);\r\n\r\n\tconst renderFooterRow = () => (\r\n\t\t\r\n\t\t\t \r\n\t\t\t{xLabels.map((label, index) => (\r\n\t\t\t\t\r\n\t\t\t\t\t{label}\r\n\t\t\t\t \r\n\t\t\t))}\r\n\t\t \r\n\t);\r\n\r\n\treturn (\r\n\t\t\r\n\t\t\t
\r\n\t\t\t\t{reversedYLabels.map((yLabel, rowIndex) => renderTableRow(yLabel, rowIndex))} \r\n\t\t\t\t{renderFooterRow()} \r\n\t\t\t
\r\n\t\t
\r\n\t);\r\n};\r\n\r\nexport default BulletChart;\r\n","// src/Histogram.js\r\nimport React from \"react\";\r\n\r\nconst Histogram = ({ objData, width = \"400\", height = 200, barColor = \"#2196f3\", axisColor = \"#000\", padding = 30, labelColor = \"#000\", barLabelColor = \"#000\", tickSize = 5, yAxisTickCount = 5 }) => {\r\n const { data } = objData;\r\n if (!data || data.length === 0) {\r\n return No data provided
;\r\n }\r\n\r\n const values = data.map((d) => d.value);\r\n const value = Math.min(...values);\r\n const maxValue = Math.max(...values);\r\n const minValue = Math.min(...values) - value;\r\n const binWidth = (width - 2 * padding) / data.length;\r\n\r\n const yAxisTickValues = Array.from({ length: yAxisTickCount }, (_, i) => minValue + (i * (maxValue - minValue)) / (yAxisTickCount - 1));\r\n\r\n return (\r\n \r\n {/* Bars */}\r\n {data.map((d, index) => {\r\n const barHeight = ((d.value - minValue) / (maxValue - minValue)) * (height - 2 * padding);\r\n const x = padding + index * binWidth;\r\n const y = height - barHeight - padding;\r\n\r\n return ;\r\n })}\r\n\r\n {/* Bar Labels */}\r\n {data.map((d, index) => {\r\n const barHeight = ((d.value - minValue) / (maxValue - minValue)) * (height - 2 * padding);\r\n const x = padding + index * binWidth + binWidth / 2;\r\n const y = height - barHeight - padding - 5;\r\n\r\n return (\r\n \r\n {d.value}\r\n \r\n );\r\n })}\r\n\r\n {/* X-Axis */}\r\n \r\n\r\n {/* X-Axis Ticks and Labels */}\r\n {data.map((d, index) => {\r\n const x = padding + index * binWidth;\r\n const y = height - padding;\r\n\r\n return (\r\n <>\r\n \r\n \r\n {d.x}\r\n \r\n >\r\n );\r\n })}\r\n\r\n {/* Y-Axis */}\r\n \r\n\r\n {/* Y-Axis Ticks and Labels */}\r\n {yAxisTickValues.map((tickValue, index) => {\r\n const y = height - padding - ((tickValue - minValue) / (maxValue - minValue)) * (height - 2 * padding);\r\n return (\r\n <>\r\n \r\n \r\n {Math.round(tickValue * 100) / 100}\r\n \r\n >\r\n );\r\n })}\r\n \r\n );\r\n};\r\n\r\nexport default Histogram;\r\n","import React, { useEffect, useRef } from 'react';\r\n\r\nconst PieChart = ({ objData, colorMapping }) => {\r\n\tconst { data } = objData;\r\n\r\n\tconst canvasRef = useRef(null);\r\n\r\n\tconst drawChart = () => {\r\n\t\tconst ctx = canvasRef.current.getContext('2d');\r\n\t\tconst totalValue = data.reduce((acc, curr) => acc + parseFloat(curr.value), 0);\r\n\t\tlet startAngle = 0;\r\n\r\n\t\tdata.forEach((item) => {\r\n\t\t\tconst value = parseFloat(item.value);\r\n\t\t\tconst sliceAngle = (2 * Math.PI * value) / totalValue;\r\n\r\n\t\t\tctx.beginPath();\r\n\t\t\tctx.moveTo(canvasRef.current.width / 2, canvasRef.current.height / 2);\r\n\t\t\tctx.arc(\r\n\t\t\t\tcanvasRef.current.width / 2,\r\n\t\t\t\tcanvasRef.current.height / 2,\r\n\t\t\t\tMath.min(canvasRef.current.width / 2, canvasRef.current.height / 2),\r\n\t\t\t\tstartAngle,\r\n\t\t\t\tstartAngle + sliceAngle\r\n\t\t\t);\r\n\t\t\tctx.closePath();\r\n\r\n\t\t\tctx.fillStyle = colorMapping?.[item.x];\r\n\t\t\tctx.fill();\r\n\r\n\t\t\t// Draw label\r\n\t\t\tconst labelX =\r\n\t\t\t\tcanvasRef.current.width / 2 +\r\n\t\t\t\t(Math.min(canvasRef.current.width / 2, canvasRef.current.height / 2) / 2) * Math.cos(startAngle + sliceAngle / 2);\r\n\t\t\tconst labelY =\r\n\t\t\t\tcanvasRef.current.height / 2 +\r\n\t\t\t\t(Math.min(canvasRef.current.width / 2, canvasRef.current.height / 2) / 2) * Math.sin(startAngle + sliceAngle / 2);\r\n\r\n\t\t\tctx.fillStyle = 'white';\r\n\t\t\tctx.font = '16px Arial';\r\n\t\t\tctx.textAlign = 'center';\r\n\t\t\tctx.textBaseline = 'middle';\r\n\t\t\tctx.fillText(item.x, labelX, labelY);\r\n\r\n\t\t\tstartAngle += sliceAngle;\r\n\t\t});\r\n\t};\r\n\r\n\tuseEffect(() => {\r\n\t\tdrawChart();\r\n\t}, []);\r\n\r\n\treturn (\r\n\t\t<>\r\n\t\t\t \r\n\t\t>\r\n\t);\r\n};\r\n\r\nexport default PieChart;\r\n","const __WEBPACK_NAMESPACE_OBJECT__ = require(\"prop-types\");","import React from \"react\";\r\nimport PropTypes from \"prop-types\";\r\n\r\nconst BoxPlot = ({\r\n data = [1, 6, 2, 3, 5],\r\n width,\r\n height,\r\n paddingLeft,\r\n paddingRight,\r\n paddingTop,\r\n paddingBottom,\r\n xLabels = [1, \"B\", \"C\", \"D\", \"E\", \"5\", \"9\"],\r\n}) => {\r\n // Sort the data\r\n const sortedData = data.slice().sort((a, b) => a - b);\r\n\r\n // Calculate quartiles\r\n const q1 = sortedData[Math.floor(sortedData.length * 0.25)];\r\n const q2 = sortedData[Math.floor(sortedData.length * 0.5)];\r\n const q3 = sortedData[Math.floor(sortedData.length * 0.75)];\r\n\r\n // Calculate interquartile range\r\n const iqr = q3 - q1;\r\n\r\n // Calculate whiskers\r\n const lowerWhisker = q1 - 1.5 * iqr;\r\n const upperWhisker = q3 + 1.5 * iqr;\r\n\r\n const innerWidth = width - paddingLeft - paddingRight;\r\n const innerHeight = height - paddingTop - paddingBottom;\r\n\r\n return (\r\n \r\n {/* Box plot */}\r\n \r\n \r\n \r\n \r\n\r\n {/* X-axis */}\r\n \r\n \r\n X-axis\r\n \r\n\r\n {/* X-axis labels */}\r\n {xLabels.map((label, index) => (\r\n \r\n {label}\r\n \r\n ))}\r\n\r\n {/* Y-axis */}\r\n \r\n \r\n Y-axis\r\n \r\n \r\n );\r\n};\r\n\r\nBoxPlot.propTypes = {\r\n data: PropTypes.arrayOf(PropTypes.number).isRequired,\r\n width: PropTypes.number,\r\n height: PropTypes.number,\r\n paddingLeft: PropTypes.number,\r\n paddingRight: PropTypes.number,\r\n paddingTop: PropTypes.number,\r\n paddingBottom: PropTypes.number,\r\n xLabels: PropTypes.arrayOf(PropTypes.string).isRequired,\r\n};\r\n\r\nBoxPlot.defaultProps = {\r\n width: 400,\r\n height: 200,\r\n paddingLeft: 40,\r\n paddingRight: 20,\r\n paddingTop: 20,\r\n paddingBottom: 40,\r\n};\r\n\r\nexport default BoxPlot;\r\n","import React from 'react';\r\nimport HeatMap from './section/HeatMap/HeatMap';\r\nimport BulletChart from './section/bulletCharts/BulletChart';\r\nimport Histogram from './section/Histogram/Histogram';\r\nimport Pie from './section/Pie/Pie';\r\nimport BoxPlot from './section/BoxPlot/BoxPlot';\r\n\r\nexport default function Charts({ mode, ...rest }) {\r\n\treturn (\r\n\t\t<>\r\n\t\t\t{mode === 'heat-map' && }\r\n\t\t\t{mode === 'bullet-charts' && }\r\n\t\t\t{mode === 'histogram' && }\r\n\t\t\t{mode === 'pie' && }\r\n\t\t\t{mode === 'box-plot' && }\r\n\t\t>\r\n\t);\r\n}\r\n","\n import API from \"!../../../../node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js\";\n import domAPI from \"!../../../../node_modules/style-loader/dist/runtime/styleDomAPI.js\";\n import insertFn from \"!../../../../node_modules/style-loader/dist/runtime/insertBySelector.js\";\n import setAttributes from \"!../../../../node_modules/style-loader/dist/runtime/setAttributesWithoutAttributes.js\";\n import insertStyleElement from \"!../../../../node_modules/style-loader/dist/runtime/insertStyleElement.js\";\n import styleTagTransformFn from \"!../../../../node_modules/style-loader/dist/runtime/styleTagTransform.js\";\n import content, * as namedExport from \"!!../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[1].use[1]!./RadialProgressBar.css\";\n \n \n\nvar options = {};\n\noptions.styleTagTransform = styleTagTransformFn;\noptions.setAttributes = setAttributes;\n\n options.insert = insertFn.bind(null, \"head\");\n \noptions.domAPI = domAPI;\noptions.insertStyleElement = insertStyleElement;\n\nvar update = API(content, options);\n\n\n\nexport * from \"!!../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[1].use[1]!./RadialProgressBar.css\";\n export default content && content.locals ? content.locals : undefined;\n","import React, { useEffect, useState } from \"react\";\r\nimport \"./RadialProgressBar.css\";\r\n\r\nfunction RadialProgressBar({ value, maxValue, color }) {\r\n const [state, setState] = useState({\r\n value: 0,\r\n backgroundImage: `linear-gradient(90deg, #ddd 50%, transparent 50%), linear-gradient(90deg, ${color} 50%, #ddd 50%)`,\r\n });\r\n\r\n useEffect(() => {\r\n const number = Math.floor((value / maxValue) * 100);\r\n state.value = number;\r\n const deg = 90 - (360 * state.value) / 100 - 1;\r\n const deg2 = 360 * ((state.value - 50) / 100) + deg;\r\n let backgroundImage =\r\n state.value <= 50 ? `linear-gradient(${deg}deg, #ddd 50%, transparent 50%), linear-gradient(90deg, ${color} 50%, #ddd 50%)` : `linear-gradient(${deg}deg, ${color} 50%, transparent 50%), linear-gradient(${deg2}deg, ${color} 50%, #ddd 50%)`;\r\n\r\n state.backgroundImage = backgroundImage;\r\n setState({ ...state });\r\n }, [value, maxValue]);\r\n\r\n return (\r\n \r\n \r\n \r\n );\r\n}\r\n\r\nexport default RadialProgressBar;\r\n","\n import API from \"!../../../../node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js\";\n import domAPI from \"!../../../../node_modules/style-loader/dist/runtime/styleDomAPI.js\";\n import insertFn from \"!../../../../node_modules/style-loader/dist/runtime/insertBySelector.js\";\n import setAttributes from \"!../../../../node_modules/style-loader/dist/runtime/setAttributesWithoutAttributes.js\";\n import insertStyleElement from \"!../../../../node_modules/style-loader/dist/runtime/insertStyleElement.js\";\n import styleTagTransformFn from \"!../../../../node_modules/style-loader/dist/runtime/styleTagTransform.js\";\n import content, * as namedExport from \"!!../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[1].use[1]!./Note.css\";\n \n \n\nvar options = {};\n\noptions.styleTagTransform = styleTagTransformFn;\noptions.setAttributes = setAttributes;\n\n options.insert = insertFn.bind(null, \"head\");\n \noptions.domAPI = domAPI;\noptions.insertStyleElement = insertStyleElement;\n\nvar update = API(content, options);\n\n\n\nexport * from \"!!../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[1].use[1]!./Note.css\";\n export default content && content.locals ? content.locals : undefined;\n","import React, { useEffect, useRef } from \"react\";\r\nimport \"./Note.css\";\r\nimport \"../../../style/main.css\";\r\nimport * as componentsFunction from \"../../../helper/CbmisFunction\";\r\nimport useCheckScreenSize from \"../../../hook/useCheckScreenSize\";\r\nimport { setSxClassName } from \"../../../helper/convertJsCss\";\r\n\r\nfunction Note(props) {\r\n const { type, sx, hidden, disabled, dir, className, id, ...rest } = props;\r\n const getID = useRef(id || componentsFunction.randomName(\"Container\"));\r\n const styleRef = useRef({ strSxClassName: \"\" });\r\n\r\n const screenWidth = useCheckScreenSize();\r\n\r\n useEffect(() => {}, [type, , hidden, disabled, dir, className, id]);\r\n\r\n useEffect(() => {\r\n if (sx) {\r\n setSxClassName(styleRef, getID.current, sx, \"cbmis-container\");\r\n }\r\n }, [sx, screenWidth]);\r\n\r\n const getRestProps = () => {\r\n const newRest = componentsFunction.filterPaddingAndMargin(rest);\r\n return { ...newRest };\r\n };\r\n\r\n const getMode = () => {\r\n switch (String(type).toLowerCase()) {\r\n case \"error\":\r\n return \"cbmis-alert-note-danger\";\r\n case \"info\":\r\n return \"cbmis-alert-note-info\";\r\n case \"success\":\r\n return \"cbmis-alert-note-success\";\r\n case \"primary\":\r\n return \"cbmis-alert-note-primary\";\r\n case \"warning\":\r\n return \"cbmis-alert-note-warning\";\r\n default:\r\n return \"cbmis-alert-note-primary\";\r\n }\r\n };\r\n\r\n return (\r\n \r\n \r\n {props.children}\r\n
\r\n \r\n );\r\n}\r\n\r\nexport default Note;\r\n","\n import API from \"!../../../../node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js\";\n import domAPI from \"!../../../../node_modules/style-loader/dist/runtime/styleDomAPI.js\";\n import insertFn from \"!../../../../node_modules/style-loader/dist/runtime/insertBySelector.js\";\n import setAttributes from \"!../../../../node_modules/style-loader/dist/runtime/setAttributesWithoutAttributes.js\";\n import insertStyleElement from \"!../../../../node_modules/style-loader/dist/runtime/insertStyleElement.js\";\n import styleTagTransformFn from \"!../../../../node_modules/style-loader/dist/runtime/styleTagTransform.js\";\n import content, * as namedExport from \"!!../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[1].use[1]!./Box.css\";\n \n \n\nvar options = {};\n\noptions.styleTagTransform = styleTagTransformFn;\noptions.setAttributes = setAttributes;\n\n options.insert = insertFn.bind(null, \"head\");\n \noptions.domAPI = domAPI;\noptions.insertStyleElement = insertStyleElement;\n\nvar update = API(content, options);\n\n\n\nexport * from \"!!../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[1].use[1]!./Box.css\";\n export default content && content.locals ? content.locals : undefined;\n","import React, { useEffect, useRef } from \"react\";\r\nimport \"./Box.css\";\r\nimport \"../../../style/main.css\";\r\nimport * as componentsFunction from \"../../../helper/CbmisFunction\";\r\nimport useCheckScreenSize from \"../../../hook/useCheckScreenSize\";\r\nimport { setSxClassName } from \"../../../helper/convertJsCss\";\r\nimport { strTestProps } from \"../../../helper/CbmisVariables\";\r\n\r\nconst Box = (props) => {\r\n const { color, outline, hoverElevation, elevation, sx, hidden, disabled, dir, className, id, ...rest } = props;\r\n const screenWidth = useCheckScreenSize();\r\n\r\n const styleRef = useRef({ strSxClassName: \"\", strSXComponentID: id || componentsFunction.randomName(\"cbmis-box\") });\r\n\r\n if(props?.[strTestProps]){\r\n if(props?.color){\r\n console.log(\"Box\", \"color\");\r\n }\r\n if(props?.outline){\r\n console.log(\"Box\", \"outline\");\r\n }\r\n if(props?.hoverElevation){\r\n console.log(\"Box\", \"hoverElevation\");\r\n }\r\n if(props?.elevation){\r\n console.log(\"Box\", \"elevation\");\r\n }\r\n if(props?.sx){\r\n console.log(\"Box\", \"sx\",);\r\n }\r\n }\r\n useEffect(() => {}, [hoverElevation, elevation, hidden, disabled, dir, className, id]);\r\n\r\n useEffect(() => {\r\n if (sx) {\r\n setSxClassName(styleRef, styleRef.current.strSXComponentID, sx, \"cbmis-box\");\r\n } else {\r\n setSxClassName(\r\n styleRef,\r\n styleRef.current.strSXComponentID,\r\n !outline || parseInt(outline) === 0\r\n ? {\r\n background: `${color} !important`,\r\n }\r\n : { borderColor: `${color} !important`, color: `${color} !important`, background: `transparent !important` },\r\n \"cbmis-box\"\r\n );\r\n }\r\n }, [sx, screenWidth, color, outline]);\r\n\r\n const getOutline = () => {\r\n switch (parseInt(outline)) {\r\n case 1:\r\n return \"cbmis-border-width-1\";\r\n case 2:\r\n return \"cbmis-border-width-2\";\r\n case 3:\r\n return \"cbmis-border-width-3\";\r\n case 4:\r\n return \"cbmis-border-width-4\";\r\n case 5:\r\n return \"cbmis-border-width-5\";\r\n\r\n default:\r\n return \"cbmis-border-width-0\";\r\n }\r\n };\r\n\r\n const getRestProps = () => {\r\n const newRest = componentsFunction.filterPaddingAndMargin(rest);\r\n return { ...newRest };\r\n };\r\n\r\n return (\r\n \r\n \r\n {props.children}\r\n
\r\n \r\n );\r\n};\r\n\r\nexport default Box;\r\n","\n import API from \"!../../../../node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js\";\n import domAPI from \"!../../../../node_modules/style-loader/dist/runtime/styleDomAPI.js\";\n import insertFn from \"!../../../../node_modules/style-loader/dist/runtime/insertBySelector.js\";\n import setAttributes from \"!../../../../node_modules/style-loader/dist/runtime/setAttributesWithoutAttributes.js\";\n import insertStyleElement from \"!../../../../node_modules/style-loader/dist/runtime/insertStyleElement.js\";\n import styleTagTransformFn from \"!../../../../node_modules/style-loader/dist/runtime/styleTagTransform.js\";\n import content, * as namedExport from \"!!../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[1].use[1]!./Container.css\";\n \n \n\nvar options = {};\n\noptions.styleTagTransform = styleTagTransformFn;\noptions.setAttributes = setAttributes;\n\n options.insert = insertFn.bind(null, \"head\");\n \noptions.domAPI = domAPI;\noptions.insertStyleElement = insertStyleElement;\n\nvar update = API(content, options);\n\n\n\nexport * from \"!!../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[1].use[1]!./Container.css\";\n export default content && content.locals ? content.locals : undefined;\n","import React, { useEffect, useRef } from \"react\";\r\nimport \"./Container.css\";\r\nimport \"../../../style/main.css\";\r\nimport * as componentsFunction from \"../../../helper/CbmisFunction\";\r\nimport useCheckScreenSize from \"../../../hook/useCheckScreenSize\";\r\nimport { setSxClassName } from \"../../../helper/convertJsCss\";\r\nimport { strTestProps } from \"../../../helper/CbmisVariables\";\r\n\r\nconst Container = (props) => {\r\n const { width, sx, hidden, disabled, dir, className, id, ...rest } = props;\r\n\r\n const screenWidth = useCheckScreenSize();\r\n const getID = useRef(id || componentsFunction.randomName(\"Container\"));\r\n const styleRef = useRef({ strSxClassName: \"\" });\r\n\r\n if(props?.[strTestProps]){\r\n if(props?.width){\r\n console.log(\"container\", \"width\");\r\n }\r\n if(props?.sx){\r\n console.log(\"container\", \"sx\",);\r\n }\r\n }\r\n useEffect(() => {}, [width, sx, hidden, disabled, dir, className, id]);\r\n\r\n useEffect(() => {\r\n if (sx) {\r\n setSxClassName(styleRef, getID.current, sx, \"cbmis-container\");\r\n }\r\n }, [sx, screenWidth]);\r\n\r\n const getWidth = () => {\r\n switch (String(width).toLowerCase()) {\r\n case \"xl\":\r\n return \"cbmis-width-xl\";\r\n case \"lg\":\r\n return \"cbmis-width-lg\";\r\n case \"md\":\r\n return \"cbmis-width-md\";\r\n case \"sm\":\r\n return \"cbmis-width-sm\";\r\n case \"fluid\":\r\n return \"cbmis-width-fluid\";\r\n case \"half\":\r\n return \"cbmis-width-half\";\r\n default:\r\n return \"\";\r\n }\r\n };\r\n\r\n const getRestProps = () => {\r\n const newRest = componentsFunction.filterPaddingAndMargin(rest);\r\n return { ...newRest };\r\n };\r\n\r\n return (\r\n \r\n \r\n {props.children}\r\n
\r\n \r\n );\r\n};\r\n\r\nexport default Container;\r\n","\n import API from \"!../../../../node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js\";\n import domAPI from \"!../../../../node_modules/style-loader/dist/runtime/styleDomAPI.js\";\n import insertFn from \"!../../../../node_modules/style-loader/dist/runtime/insertBySelector.js\";\n import setAttributes from \"!../../../../node_modules/style-loader/dist/runtime/setAttributesWithoutAttributes.js\";\n import insertStyleElement from \"!../../../../node_modules/style-loader/dist/runtime/insertStyleElement.js\";\n import styleTagTransformFn from \"!../../../../node_modules/style-loader/dist/runtime/styleTagTransform.js\";\n import content, * as namedExport from \"!!../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[1].use[1]!./BottomBar.css\";\n \n \n\nvar options = {};\n\noptions.styleTagTransform = styleTagTransformFn;\noptions.setAttributes = setAttributes;\n\n options.insert = insertFn.bind(null, \"head\");\n \noptions.domAPI = domAPI;\noptions.insertStyleElement = insertStyleElement;\n\nvar update = API(content, options);\n\n\n\nexport * from \"!!../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[1].use[1]!./BottomBar.css\";\n export default content && content.locals ? content.locals : undefined;\n","import React, { useEffect, useRef } from \"react\";\r\nimport \"./BottomBar.css\";\r\nimport Icon from \"../../../icon/CbmisIcon\";\r\nimport { useNavigate } from \"react-router-dom\";\r\nimport \"../../../style/main.css\";\r\nimport * as componentsFunction from \"../../../helper/CbmisFunction\";\r\nimport useCheckScreenSize from \"../../../hook/useCheckScreenSize\";\r\nimport { setSxClassName } from \"../../../helper/convertJsCss\";\r\n\r\nfunction BottomBar(props) {\r\n const { content, activeColor, sx, hidden, disabled, dir, className, id, tab, ...rest } = props;\r\n\r\n const screenWidth = useCheckScreenSize();\r\n const navigate = useNavigate();\r\n const pathName = window.location.pathname;\r\n\r\n const styleRef = useRef({ strSxClassName: \"\", strSXComponentID: id || componentsFunction.randomName(\"cbmis-bottom-bar\") });\r\n\r\n const getRestProps = () => {\r\n const newRest = componentsFunction.filterPaddingAndMargin(rest);\r\n return { ...newRest };\r\n };\r\n\r\n const handleClicked = (index, onClick, path, blank) => {\r\n if (onClick) {\r\n onClick();\r\n }\r\n if (String(path)[0] === \"#\" || String(path)[0] === \".\") {\r\n if (String(path).length > 1) componentsFunction.scrollToElement(path);\r\n } else if (path && (String(path).toLowerCase().includes(\".com\") || String(path).toLowerCase().includes(\"http\"))) {\r\n window.open(`${path}`, blank ? \"_blank\" : \"_self\", \"\", true);\r\n } else if (path) {\r\n navigate(path);\r\n }\r\n };\r\n\r\n useEffect(() => {}, [content, sx, hidden, disabled, dir, className, id, tab]);\r\n\r\n const bodyMarginBottom = () => {\r\n document.body.style.paddingBottom = \"75px\";\r\n const drawer = document.querySelector(\".cbmis-drawer\");\r\n if (drawer) {\r\n drawer.style.maxHeight = \"93.32%\";\r\n }\r\n };\r\n\r\n useEffect(() => {\r\n if (content.length) {\r\n bodyMarginBottom();\r\n }\r\n }, []);\r\n\r\n useEffect(() => {\r\n if (sx) {\r\n setSxClassName(styleRef, styleRef.current.strSXComponentID, sx, \"cbmis-bottom-bar\");\r\n }\r\n }, [sx, screenWidth]);\r\n\r\n return content?.length ? (\r\n \r\n 5 ? \"cbmis-bottom-bar-scroll\" : \"\"} ${componentsFunction.CheckDirectionItem(\r\n dir\r\n )} ${componentsFunction.CheckDisabledItem(disabled)} ${componentsFunction.CheckHiddenItem(hidden)} ${componentsFunction.checkExistsMargin(\r\n rest\r\n )} ${componentsFunction.checkExistsPadding(rest)} ${className || \"\"}`}\r\n {...getRestProps()}\r\n >\r\n {content.map((item, index) => {\r\n return (\r\n handleClicked(index, item.onClick, item.path || \"\")}\r\n >\r\n \r\n {item.label ? {item.label} : \"\"}\r\n \r\n );\r\n })}\r\n
\r\n \r\n ) : null;\r\n}\r\n\r\nexport default BottomBar;\r\n","\n import API from \"!../../../../node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js\";\n import domAPI from \"!../../../../node_modules/style-loader/dist/runtime/styleDomAPI.js\";\n import insertFn from \"!../../../../node_modules/style-loader/dist/runtime/insertBySelector.js\";\n import setAttributes from \"!../../../../node_modules/style-loader/dist/runtime/setAttributesWithoutAttributes.js\";\n import insertStyleElement from \"!../../../../node_modules/style-loader/dist/runtime/insertStyleElement.js\";\n import styleTagTransformFn from \"!../../../../node_modules/style-loader/dist/runtime/styleTagTransform.js\";\n import content, * as namedExport from \"!!../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[1].use[1]!./Breadcrumbs.css\";\n \n \n\nvar options = {};\n\noptions.styleTagTransform = styleTagTransformFn;\noptions.setAttributes = setAttributes;\n\n options.insert = insertFn.bind(null, \"head\");\n \noptions.domAPI = domAPI;\noptions.insertStyleElement = insertStyleElement;\n\nvar update = API(content, options);\n\n\n\nexport * from \"!!../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[1].use[1]!./Breadcrumbs.css\";\n export default content && content.locals ? content.locals : undefined;\n","import React, { useEffect, useRef } from \"react\";\r\nimport \"./Breadcrumbs.css\";\r\nimport \"../../../style/main.css\";\r\nimport * as componentsFunction from \"../../../helper/CbmisFunction\";\r\nimport \"../../../style/main.css\";\r\nimport useCheckScreenSize from \"../../../hook/useCheckScreenSize\";\r\nimport { setSxClassName } from \"../../../helper/convertJsCss\";\r\n\r\nconst Breadcrumbs = (props) => {\r\n const { separator, breadcrumbs, textColor, sx, hidden, disabled, dir, className, id, ...rest } = props;\r\n\r\n const screenWidth = useCheckScreenSize();\r\n\r\n const getID = useRef(id || componentsFunction.randomName(\"Breadcrumbs\"));\r\n const styleRef = useRef({ strSxClassName: \"\" });\r\n\r\n const getRestProps = () => {\r\n const newRest = componentsFunction.filterPaddingAndMargin(rest);\r\n return { ...newRest };\r\n };\r\n\r\n useEffect(() => {}, [separator, breadcrumbs, textColor, hidden, disabled, dir, className, id]);\r\n\r\n useEffect(() => {\r\n if (styleRef.current.strSxClassName) {\r\n componentsFunction.changeItemColor(\".\" + styleRef.current.strSxClassName, textColor || \"var(--cbmis-gray-700)\");\r\n }\r\n }, [styleRef.current.strSxClassName]);\r\n\r\n useEffect(() => {\r\n if (sx) {\r\n setSxClassName(styleRef, getID.current, sx, \"cbmis-breadcrumb-item\");\r\n }\r\n }, [sx, screenWidth]);\r\n\r\n return (\r\n \r\n {breadcrumbs && breadcrumbs.length > 0\r\n ? breadcrumbs.map((item, index) => {\r\n return (\r\n \r\n {item}\r\n {separator ? separator : \"/\"} \r\n \r\n );\r\n })\r\n : \"\"}\r\n \r\n );\r\n};\r\n\r\nexport default Breadcrumbs;\r\n","\n import API from \"!../../../../node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js\";\n import domAPI from \"!../../../../node_modules/style-loader/dist/runtime/styleDomAPI.js\";\n import insertFn from \"!../../../../node_modules/style-loader/dist/runtime/insertBySelector.js\";\n import setAttributes from \"!../../../../node_modules/style-loader/dist/runtime/setAttributesWithoutAttributes.js\";\n import insertStyleElement from \"!../../../../node_modules/style-loader/dist/runtime/insertStyleElement.js\";\n import styleTagTransformFn from \"!../../../../node_modules/style-loader/dist/runtime/styleTagTransform.js\";\n import content, * as namedExport from \"!!../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[1].use[1]!./Drawer.css\";\n \n \n\nvar options = {};\n\noptions.styleTagTransform = styleTagTransformFn;\noptions.setAttributes = setAttributes;\n\n options.insert = insertFn.bind(null, \"head\");\n \noptions.domAPI = domAPI;\noptions.insertStyleElement = insertStyleElement;\n\nvar update = API(content, options);\n\n\n\nexport * from \"!!../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[1].use[1]!./Drawer.css\";\n export default content && content.locals ? content.locals : undefined;\n","import React, { useEffect, useRef } from \"react\";\r\nimport \"./Drawer.css\";\r\nimport Icon from \"../../../icon/CbmisIcon\";\r\nimport \"../../../style/main.css\";\r\nimport * as componentsFunction from \"../../../helper/CbmisFunction\";\r\nimport useCheckScreenSize from \"../../../hook/useCheckScreenSize\";\r\nimport { setSxClassName } from \"../../../helper/convertJsCss\";\r\n\r\nconst Drawer = (props) => {\r\n const { open, position, eventClose, color, title, blnHaveTitle= true, mode, textColor, width, sx, hidden, disabled, dir, className, id, ...rest } = props;\r\n\r\n const screenWidth = useCheckScreenSize();\r\n\r\n const getID = useRef(id || componentsFunction.randomName(\"Drawer\"));\r\n const styleRef = useRef({ strSxClassName: \"\" });\r\n\r\n useEffect(() => {}, [open, position, eventClose, mode, color, sx, hidden, disabled, dir, className, sx]);\r\n\r\n useEffect(() => {\r\n if (styleRef.current.strSxClassName) {\r\n if (color) {\r\n componentsFunction.getbgColorReturnClassName(`.${styleRef.current.strSxClassName} .cbmis-drawer`, color);\r\n } else {\r\n componentsFunction.getbgColorReturnClassName(`.${styleRef.current.strSxClassName} .cbmis-drawer`, \"var(--cbmis-white)\");\r\n }\r\n }\r\n }, [styleRef.current.strSxClassName, color]);\r\n\r\n useEffect(() => {\r\n if (styleRef.current.strSxClassName) {\r\n if (textColor) {\r\n componentsFunction.changeItemColor(`.${styleRef.current.strSxClassName} .cbmis-drawer`, textColor);\r\n } else {\r\n componentsFunction.changeItemColor(`.${styleRef.current.strSxClassName} .cbmis-drawer`, \"var(--cbmis-dark)\");\r\n }\r\n }\r\n }, [styleRef.current.strSxClassName, textColor]);\r\n\r\n useEffect(() => {\r\n if (sx) {\r\n setSxClassName(styleRef, getID.current, sx, \"cbmis-drawer-container\");\r\n }\r\n }, [sx, screenWidth]);\r\n\r\n const getRestProps = () => {\r\n const newRest = componentsFunction.filterPaddingAndMargin(rest);\r\n return { ...newRest };\r\n };\r\n\r\n const handlePositionChange = () => {\r\n if (position) {\r\n const getPostion = String(position).toLowerCase();\r\n switch (getPostion) {\r\n case \"top\":\r\n return \"cbmis-drawer-position-top cbmis-drawer-open-100\";\r\n case \"left\":\r\n return \"cbmis-drawer-position-left\";\r\n case \"bottom\":\r\n return \"cbmis-drawer-position-bottom cbmis-drawer-open-100\";\r\n case \"right\":\r\n return \"cbmis-drawer-position-right\";\r\n default:\r\n break;\r\n }\r\n } else if (document.querySelector(\".cbmis-body-dir-rtl\")) {\r\n return \"cbmis-drawer-position-right\";\r\n } else {\r\n return \"cbmis-drawer-position-left\";\r\n }\r\n };\r\n\r\n const handleClose = (e) => {\r\n if (eventClose) {\r\n eventClose();\r\n }\r\n };\r\n\r\n const bodyMarginLeft = () => {\r\n document.body.style.paddingLeft = \"5.1vw\";\r\n };\r\n const getMode = () => {\r\n switch (String(mode).toLowerCase()) {\r\n case \"overlay\":\r\n return \"cbmis-drawer-persistent\";\r\n case \"overlay-opacity\":\r\n return \"cbmis-drawer-opacity\";\r\n case \"show-header\":\r\n bodyMarginLeft();\r\n return \"cbmis-drawer-persistent cbmis-drawer-show-header\";\r\n default:\r\n return \"cbmis-drawer-persistent\";\r\n }\r\n };\r\n\r\n const getWidth = () => {\r\n if (width) {\r\n return `cbmis-drawer-open-${String(width).toLowerCase()}`;\r\n } else {\r\n return \"\";\r\n }\r\n };\r\n\r\n return (\r\n \r\n {eventClose && open ?
: \"\"}\r\n
\r\n {String(mode).toLowerCase() !== \"show-header\" && blnHaveTitle? (\r\n
\r\n {title ? title : \"\"} \r\n {eventClose ? : \"\"}\r\n
\r\n ) : (\r\n \"\"\r\n )}\r\n
{props.children}
\r\n
\r\n
\r\n );\r\n};\r\n\r\nexport default Drawer;\r\n","\n import API from \"!../../../../node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js\";\n import domAPI from \"!../../../../node_modules/style-loader/dist/runtime/styleDomAPI.js\";\n import insertFn from \"!../../../../node_modules/style-loader/dist/runtime/insertBySelector.js\";\n import setAttributes from \"!../../../../node_modules/style-loader/dist/runtime/setAttributesWithoutAttributes.js\";\n import insertStyleElement from \"!../../../../node_modules/style-loader/dist/runtime/insertStyleElement.js\";\n import styleTagTransformFn from \"!../../../../node_modules/style-loader/dist/runtime/styleTagTransform.js\";\n import content, * as namedExport from \"!!../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[1].use[1]!./Pagination.css\";\n \n \n\nvar options = {};\n\noptions.styleTagTransform = styleTagTransformFn;\noptions.setAttributes = setAttributes;\n\n options.insert = insertFn.bind(null, \"head\");\n \noptions.domAPI = domAPI;\noptions.insertStyleElement = insertStyleElement;\n\nvar update = API(content, options);\n\n\n\nexport * from \"!!../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[1].use[1]!./Pagination.css\";\n export default content && content.locals ? content.locals : undefined;\n","import React, { useEffect, useState } from 'react'\r\nimport './Pagination.css'\r\nimport CbmisIcon from '../../../icon/CbmisIcon'\r\nimport '../../../style/main.css'\r\nimport * as componentsFunction from '../../../helper/CbmisFunction'\r\nimport useCheckScreenSize from '../../../hook/useCheckScreenSize'\r\nimport { setSXStyle } from '../../../helper/convertJsCss'\r\n\r\nconst Pagination=(props) => {\r\n useCheckScreenSize()\r\n const {count,setStyle,color,textColor} =props\r\n const [arrPagination, setArrPagination] = useState([])\r\n const [paginationStyle, setpaginationStyle] = useState(\"cbmis-pagination-filled\")\r\n\r\n useEffect(() => {\r\n const array = [];\r\n for (let index = 1; index <= parseInt(count); index++) {\r\n array.push(index)\r\n }\r\n setArrPagination(array)\r\n }, [count])\r\n\r\n useEffect(() => {\r\n if(setStyle){\r\n const paginationStyle = String(setStyle).toLowerCase()\r\n switch (paginationStyle) {\r\n case \"outlined\":\r\n setpaginationStyle(\"cbmis-pagination-outlined\")\r\n break; \r\n default:\r\n setpaginationStyle(\"cbmis-pagination-filled\")\r\n break;\r\n }\r\n }\r\n }, [setStyle])\r\n\r\n useEffect(() => {\r\n if(paginationStyle === \"cbmis-pagination-filled\"){\r\n componentsFunction.getbgColorReturnClassName(\".cbmis-pagination-filled\",color)\r\n }else if(paginationStyle === \"cbmis-pagination-outlined\"){\r\n componentsFunction.getOutlinedStyleColorReturnClassName(\".cbmis-pagination-outlined\",color)\r\n }\r\n }, [paginationStyle,color])\r\n\r\n useEffect(() => {\r\n componentsFunction.changeItemColor(\".cbmis-pagination\",textColor || \"var(--cbmis-body-color)\")\r\n }, [textColor])\r\n\r\n return (\r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n {\r\n arrPagination.map((item,index)=>{\r\n return \r\n {item} \r\n \r\n })\r\n }\r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n )\r\n}\r\n\r\nexport default Pagination\r\n","\n import API from \"!../../../../node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js\";\n import domAPI from \"!../../../../node_modules/style-loader/dist/runtime/styleDomAPI.js\";\n import insertFn from \"!../../../../node_modules/style-loader/dist/runtime/insertBySelector.js\";\n import setAttributes from \"!../../../../node_modules/style-loader/dist/runtime/setAttributesWithoutAttributes.js\";\n import insertStyleElement from \"!../../../../node_modules/style-loader/dist/runtime/insertStyleElement.js\";\n import styleTagTransformFn from \"!../../../../node_modules/style-loader/dist/runtime/styleTagTransform.js\";\n import content, * as namedExport from \"!!../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[1].use[1]!./SpeedDial.css\";\n \n \n\nvar options = {};\n\noptions.styleTagTransform = styleTagTransformFn;\noptions.setAttributes = setAttributes;\n\n options.insert = insertFn.bind(null, \"head\");\n \noptions.domAPI = domAPI;\noptions.insertStyleElement = insertStyleElement;\n\nvar update = API(content, options);\n\n\n\nexport * from \"!!../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[1].use[1]!./SpeedDial.css\";\n export default content && content.locals ? content.locals : undefined;\n","import React, { useEffect, useRef } from \"react\";\r\nimport \"./SpeedDial.css\";\r\nimport \"../../../style/main.css\";\r\nimport CbmisIcon from \"../../../icon/CbmisIcon\";\r\nimport * as componentsFunction from \"../../../helper/CbmisFunction\";\r\nimport useCheckScreenSize from \"../../../hook/useCheckScreenSize\";\r\nimport { setSxClassName } from \"../../../helper/convertJsCss\";\r\n\r\nconst SpeedDial = (props) => {\r\n const { icon, openIcon, direction, sx, hidden, disabled, dir, className, onClick, id, ...rest } = props;\r\n\r\n const screenWidth = useCheckScreenSize();\r\n const getID = useRef(id || componentsFunction.randomName(\"SpeedDial\"));\r\n const styleRef = useRef({ strSxClassName: \"\" });\r\n\r\n useEffect(() => {}, [icon, openIcon, direction, hidden, disabled, dir, className, onClick, id]);\r\n\r\n useEffect(() => {\r\n if (sx) {\r\n setSxClassName(styleRef, getID.current, sx, \"cbmis-speed-dial\");\r\n }\r\n }, [sx, screenWidth]);\r\n\r\n const handleClicked = () => {\r\n if (onClick) {\r\n onClick();\r\n }\r\n };\r\n\r\n const getRestProps = () => {\r\n const newRest = componentsFunction.filterPaddingAndMargin(rest);\r\n return { ...newRest };\r\n };\r\n\r\n const getSpeedDialDirection = () => {\r\n const getDirection = String(direction).toLowerCase();\r\n switch (getDirection) {\r\n case \"up\":\r\n return \"cbmis-speed-dial-direction-up\";\r\n case \"left\":\r\n return \"cbmis-speed-dial-direction-left\";\r\n case \"bottom\":\r\n return \"cbmis-speed-dial-direction-bottom\";\r\n case \"right\":\r\n return \"cbmis-speed-dial-direction-right\";\r\n default:\r\n return \"cbmis-speed-dial-direction-up\";\r\n }\r\n };\r\n\r\n return (\r\n \r\n
{icon ? icon : }
\r\n
{openIcon ? openIcon : }
\r\n
\r\n
\r\n );\r\n};\r\n\r\nexport default SpeedDial;\r\n","import React, { useEffect, useRef } from \"react\";\r\nimport \"./SpeedDial.css\";\r\nimport \"../../../style/main.css\";\r\nimport * as componentsFunction from \"../../../helper/CbmisFunction\";\r\nimport useCheckScreenSize from \"../../../hook/useCheckScreenSize\";\r\nimport { setSxClassName } from \"../../../helper/convertJsCss\";\r\n\r\nconst SpeedDialAction = (props) => {\r\n const { sx, hidden, disabled, dir, className, onClick, id, ...rest } = props;\r\n\r\n const screenWidth = useCheckScreenSize();\r\n\r\n const getID = useRef(id || componentsFunction.randomName(\"SpeedDialAction\"));\r\n const styleRef = useRef({ strSxClassName: \"\" });\r\n\r\n const handleClicked = () => {\r\n if (onClick) {\r\n onClick();\r\n }\r\n };\r\n\r\n const getRestProps = () => {\r\n const newRest = componentsFunction.filterPaddingAndMargin(rest);\r\n return { ...newRest };\r\n };\r\n\r\n useEffect(() => {}, [hidden, disabled, dir, className, onClick, id]);\r\n\r\n useEffect(() => {\r\n if (sx) {\r\n setSxClassName(styleRef, getID.current, sx, \"cbmis-speed-dial-action\");\r\n }\r\n }, [sx, screenWidth]);\r\n\r\n return (\r\n \r\n {props.children}\r\n
\r\n );\r\n};\r\n\r\nexport default SpeedDialAction;\r\n","\n import API from \"!../../../../node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js\";\n import domAPI from \"!../../../../node_modules/style-loader/dist/runtime/styleDomAPI.js\";\n import insertFn from \"!../../../../node_modules/style-loader/dist/runtime/insertBySelector.js\";\n import setAttributes from \"!../../../../node_modules/style-loader/dist/runtime/setAttributesWithoutAttributes.js\";\n import insertStyleElement from \"!../../../../node_modules/style-loader/dist/runtime/insertStyleElement.js\";\n import styleTagTransformFn from \"!../../../../node_modules/style-loader/dist/runtime/styleTagTransform.js\";\n import content, * as namedExport from \"!!../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[1].use[1]!./Stepper.css\";\n \n \n\nvar options = {};\n\noptions.styleTagTransform = styleTagTransformFn;\noptions.setAttributes = setAttributes;\n\n options.insert = insertFn.bind(null, \"head\");\n \noptions.domAPI = domAPI;\noptions.insertStyleElement = insertStyleElement;\n\nvar update = API(content, options);\n\n\n\nexport * from \"!!../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[1].use[1]!./Stepper.css\";\n export default content && content.locals ? content.locals : undefined;\n","import React, { useEffect, useRef } from \"react\";\r\nimport \"./Stepper.css\";\r\nimport \"../../../style/main.css\";\r\nimport Icon from \"../../../icon/CbmisIcon\";\r\nimport * as componentsFunction from \"../../../helper/CbmisFunction\";\r\nimport useCheckScreenSize from \"../../../hook/useCheckScreenSize\";\r\nimport { setSxClassName } from \"../../../helper/convertJsCss\";\r\n\r\nfunction Step(props) {\r\n const { indicator, stepClicked, label, navigateToStepHandler, index, mode, isActive, isComplete, isWarning, isError, completedColor, sx, className, id, ...rest } = props;\r\n\r\n const screenWidth = useCheckScreenSize();\r\n\r\n const styleRef = useRef({ strSxClassName: \"\", strSXComponentID: id || componentsFunction.randomName(\"cbmis-is-stepper-complete\") });\r\n\r\n const classes = [\"\"];\r\n if (isActive) {\r\n classes.push(\"cbmis-is-stepper-active\");\r\n }\r\n if (isComplete) {\r\n classes.push(\"cbmis-is-stepper-complete\");\r\n }\r\n if (isWarning) {\r\n classes.push(\"cbmis-is-stepper-warning\");\r\n }\r\n if (isError) {\r\n classes.push(\"cbmis-is-stepper-error\");\r\n }\r\n\r\n const handleStepClicked = (index) =>(event)=> {\r\n if (typeof stepClicked === \"undefined\" || stepClicked) {\r\n navigateToStepHandler(index);\r\n if(props?.onClick){\r\n props?.onClick(event)\r\n }\r\n }\r\n };\r\n\r\n useEffect(() => {}, [indicator, stepClicked, label, navigateToStepHandler, index, mode, isActive, isComplete, isWarning, isError, completedColor, sx, className]);\r\n\r\n useEffect(() => {\r\n if (completedColor && isComplete) {\r\n componentsFunction.getbgColorReturnClassName(`.${styleRef.current.strSxClassName} .cbmis-stepper-indicator-info`, completedColor);\r\n componentsFunction.changeItemBorderColor(`.${styleRef.current.strSxClassName} .cbmis-stepper-indicator-info`, completedColor);\r\n componentsFunction.changeItemColor(`.${styleRef.current.strSxClassName} .cbmis-stepper-label`, completedColor);\r\n }\r\n }, [isComplete]);\r\n\r\n useEffect(() => {\r\n if (sx) {\r\n setSxClassName(styleRef, styleRef.current.strSXComponentID, sx, \"cbmis-is-stepper-complete\");\r\n }\r\n }, [sx, screenWidth]);\r\n\r\n return (\r\n \r\n
\r\n handleStepClicked(index)}\r\n {...rest}\r\n >\r\n {String(mode).toLowerCase() !== \"dot\" ? (\r\n isComplete || isError || isWarning ? (\r\n \r\n ) : (\r\n indicator\r\n )\r\n ) : (\r\n \"\"\r\n )}\r\n \r\n
\r\n {String(mode).toLowerCase() !== \"dot\" ?
{label}
: \"\"}\r\n
\r\n );\r\n}\r\n\r\nexport default Step;\r\n","import React, { useEffect, useRef } from 'react'\r\nimport Step from './Step'\r\nimport './Stepper.css'\r\nimport '../../../style/main.css'\r\n\r\nfunction StepperHead(props) {\r\n const {stepperContent,stepClicked,navigateToStepHandler,mode,currentTabIndex,completedColor,sx,className} = props\r\n\t\r\n\tuseEffect(() => {\r\n\t}, [stepperContent,stepClicked,navigateToStepHandler,mode,currentTabIndex,completedColor,sx,className])\r\n\t\r\n\treturn (\r\n \r\n\t\t{stepperContent.map((el, i) => (\r\n\t\t\t \r\n\t\t))}\r\n\t
\r\n )\r\n}\r\n\r\nexport default StepperHead\r\n","import React, { useEffect, useState, Fragment, useRef } from \"react\";\r\nimport \"./Stepper.css\";\r\nimport \"../../../style/main.css\";\r\nimport * as componentsFunction from \"../../../helper/CbmisFunction\";\r\nimport useCheckScreenSize from \"../../../hook/useCheckScreenSize\";\r\nimport StepperHead from \"./StepperHead\";\r\nimport { setSxClassName } from \"../../../helper/convertJsCss\";\r\n\r\nfunction Stepper(props) {\r\n const { mode, stepperContent, currentTab, completedColor, activeColor, stepClicked, sx, hidden, disabled, dir, className, id, ...rest } = props;\r\n\r\n const screenWidth = useCheckScreenSize();\r\n\r\n const getID = useRef(id || componentsFunction.randomName(\"Stepper\"));\r\n const styleRef = useRef({ strSxClassName: \"\" });\r\n const [currentTabIndex, setCurrentTabIndex] = useState(0);\r\n const [stepperContentArr, setStepperContentArr] = useState([]);\r\n\r\n const navigateToStepHandler = (index) => {\r\n if (index !== currentTabIndex) {\r\n setCurrentTabIndex(index);\r\n }\r\n };\r\n\r\n const getRestProps = () => {\r\n const newRest = componentsFunction.filterPaddingAndMargin(rest);\r\n return { ...newRest };\r\n };\r\n\r\n useEffect(() => {}, [mode, stepperContent, currentTab, completedColor, stepClicked, activeColor, hidden, disabled, dir, className, id]);\r\n\r\n useEffect(() => {\r\n if (currentTab && parseInt(currentTab) > 1) {\r\n setCurrentTabIndex(parseInt(currentTab) - 1);\r\n } else {\r\n setCurrentTabIndex(0);\r\n }\r\n }, [currentTab]);\r\n\r\n useEffect(() => {\r\n if (stepperContent) {\r\n setStepperContentArr(stepperContent || []);\r\n }\r\n }, [stepperContent]);\r\n\r\n useEffect(() => {\r\n document.documentElement.style.setProperty(\"--cbmis-active-color\", componentsFunction.checkColorReturnValue(activeColor || \"var(--cbmis-gary)\"));\r\n }, [styleRef.current.strSxClassName]);\r\n\r\n useEffect(() => {\r\n if (sx) {\r\n setSxClassName(styleRef, getID.current, sx, \"cbmis-stepper-wrapper\");\r\n }\r\n }, [sx, screenWidth]);\r\n\r\n return (\r\n \r\n
\r\n
\r\n
\r\n {stepperContentArr.map((el, i) => (\r\n {i === currentTabIndex && el.content} \r\n ))}\r\n
\r\n
\r\n
\r\n );\r\n}\r\n\r\nexport default Stepper;\r\n","\n import API from \"!../../../../node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js\";\n import domAPI from \"!../../../../node_modules/style-loader/dist/runtime/styleDomAPI.js\";\n import insertFn from \"!../../../../node_modules/style-loader/dist/runtime/insertBySelector.js\";\n import setAttributes from \"!../../../../node_modules/style-loader/dist/runtime/setAttributesWithoutAttributes.js\";\n import insertStyleElement from \"!../../../../node_modules/style-loader/dist/runtime/insertStyleElement.js\";\n import styleTagTransformFn from \"!../../../../node_modules/style-loader/dist/runtime/styleTagTransform.js\";\n import content, * as namedExport from \"!!../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[1].use[1]!./Slideshow.css\";\n \n \n\nvar options = {};\n\noptions.styleTagTransform = styleTagTransformFn;\noptions.setAttributes = setAttributes;\n\n options.insert = insertFn.bind(null, \"head\");\n \noptions.domAPI = domAPI;\noptions.insertStyleElement = insertStyleElement;\n\nvar update = API(content, options);\n\n\n\nexport * from \"!!../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[1].use[1]!./Slideshow.css\";\n export default content && content.locals ? content.locals : undefined;\n","import React, { useEffect, useState, useRef } from \"react\";\r\nimport \"./Slideshow.css\";\r\nimport \"../../../style/main.css\";\r\nimport CbmisIcon from \"../../../icon/CbmisIcon\";\r\nimport VideoPlayer from \"../../dataDisplay/videoPlayer/VideoPlayer\";\r\nimport * as componentsFunction from \"../../../helper/CbmisFunction\";\r\nimport useCheckScreenSize from \"../../../hook/useCheckScreenSize\";\r\nimport { setSxClassName, setSXStyle } from \"../../../helper/convertJsCss\";\r\n\r\nfunction Slideshow(props) {\r\n const { slides = [], autoShow, delay, activeColor, dotsShow, slideNumber = 1, sx, hidden, disabled, dir, className, ...rest } = props;\r\n\r\n const screenWidth = useCheckScreenSize();\r\n\r\n const [index, setIndex] = useState(0);\r\n const timeoutRef = useRef(null);\r\n const styleRef = useRef({ strSxClassName: \"\", strSXComponentID: componentsFunction.randomName(\"cbmis-slid-show\") });\r\n const sliderSplitNum = new Array(Math.round(slides.length / slideNumber));\r\n const extraSlide = slides.length % slideNumber;\r\n\r\n const canMove = Math.round(slides.length / slideNumber) > 1;\r\n const isAutoShow = autoShow && canMove;\r\n const timeDelay = delay || 3000;\r\n\r\n useEffect(() => {}, [slides, autoShow, delay, activeColor, dotsShow, sx, hidden, disabled, dir, className]);\r\n\r\n useEffect(() => {\r\n if (isAutoShow) {\r\n resetTimeout();\r\n timeoutRef.current = setTimeout(() => setIndex((prevIndex) => (prevIndex === slides.length - 1 ? 0 : prevIndex + 1)), timeDelay);\r\n\r\n return () => {\r\n resetTimeout();\r\n };\r\n }\r\n }, [index]);\r\n\r\n useEffect(() => {\r\n if (activeColor) {\r\n document.documentElement.style.setProperty(\"--cbmis-slideshow-active-color\", componentsFunction.checkColorReturnValue(activeColor));\r\n }\r\n }, []);\r\n\r\n useEffect(() => {\r\n if (sx) {\r\n setSxClassName(styleRef, styleRef.current.strSXComponentID, sx, \"cbmis-slid-show\");\r\n }\r\n }, [sx, screenWidth]);\r\n\r\n function resetTimeout() {\r\n if (timeoutRef.current) {\r\n clearTimeout(timeoutRef.current);\r\n }\r\n }\r\n\r\n const handelNext = () => {\r\n if (canMove) {\r\n var next = index + 1;\r\n if (next === sliderSplitNum.length) {\r\n next = 0;\r\n }\r\n setIndex(next);\r\n }\r\n };\r\n\r\n const handelPrev = () => {\r\n if (canMove) {\r\n var Prev = index - 1;\r\n if (Prev === -1) {\r\n Prev = sliderSplitNum.length - 1;\r\n }\r\n setIndex(Prev);\r\n }\r\n };\r\n\r\n const getRestProps = () => {\r\n const newRest = componentsFunction.filterPaddingAndMargin(rest);\r\n return { ...newRest };\r\n };\r\n\r\n return (\r\n \r\n {canMove ? (\r\n
\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n \r\n ) : (\r\n \"\"\r\n )}\r\n {dotsShow && canMove? (\r\n
\r\n {slides.map((_, idx) => (\r\n
{\r\n setIndex(idx);\r\n }}\r\n >
\r\n ))}\r\n
\r\n ) : (\r\n \"\"\r\n )}\r\n\r\n
\r\n {slides.map((slide, index) => (\r\n
\r\n {!slide.videoMp4 ?
{slide.content}
:
}\r\n
\r\n ))}\r\n {slides.map((slide, index) => { setSXStyle(`cbmis-slide-${index}`, slide.sx);\r\n return index < extraSlide ? (\r\n
\r\n {!slide.videoMp4 ?
{slide.content}
:
}\r\n
\r\n ) : null;\r\n })}\r\n
\r\n
\r\n );\r\n}\r\n\r\nexport default Slideshow;\r\n","\n import API from \"!../../../../node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js\";\n import domAPI from \"!../../../../node_modules/style-loader/dist/runtime/styleDomAPI.js\";\n import insertFn from \"!../../../../node_modules/style-loader/dist/runtime/insertBySelector.js\";\n import setAttributes from \"!../../../../node_modules/style-loader/dist/runtime/setAttributesWithoutAttributes.js\";\n import insertStyleElement from \"!../../../../node_modules/style-loader/dist/runtime/insertStyleElement.js\";\n import styleTagTransformFn from \"!../../../../node_modules/style-loader/dist/runtime/styleTagTransform.js\";\n import content, * as namedExport from \"!!../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[1].use[1]!./Tab.css\";\n \n \n\nvar options = {};\n\noptions.styleTagTransform = styleTagTransformFn;\noptions.setAttributes = setAttributes;\n\n options.insert = insertFn.bind(null, \"head\");\n \noptions.domAPI = domAPI;\noptions.insertStyleElement = insertStyleElement;\n\nvar update = API(content, options);\n\n\n\nexport * from \"!!../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[1].use[1]!./Tab.css\";\n export default content && content.locals ? content.locals : undefined;\n","import React, { useEffect, useRef } from \"react\";\r\nimport \"./Tab.css\";\r\nimport \"../../../style/main.css\";\r\nimport * as componentsFunction from \"../../../helper/CbmisFunction\";\r\nimport { setSxClassName } from \"../../../helper/convertJsCss\";\r\nimport useCheckScreenSize from \"../../../hook/useCheckScreenSize\";\r\nimport Button from \"../../inputs/Button/Button\";\r\n\r\nfunction TabsHead(props) {\r\n const { tabsContent, navigateTotabHandler, currentTabIndex, activeColor, className, dir, hidden, disabled, sx, ...rest } = props;\r\n\r\n const screenWidth = useCheckScreenSize();\r\n\r\n const getNameInput = componentsFunction.randomName(\"tab-input\");\r\n const styleRef = useRef({ strSxClassName: \"\", strSXComponentID: componentsFunction.randomName(\"cbmis-tab\") });\r\n\r\n useEffect(() => {}, [tabsContent, navigateTotabHandler, currentTabIndex, activeColor, className, dir, hidden, disabled, sx]);\r\n\r\n useEffect(() => {\r\n if (sx) {\r\n setSxClassName(styleRef, styleRef.current.strSXComponentID, sx, \"cbmis-tab\");\r\n }\r\n }, [sx, screenWidth]);\r\n\r\n useEffect(() => {\r\n getScroll();\r\n }, [tabsContent]);\r\n\r\n const handleTabClicked = (e, i, el) => {\r\n navigateTotabHandler(i);\r\n if (el.onChange) {\r\n el.onChange(e);\r\n }\r\n };\r\n\r\n const getRestProps = () => {\r\n const newRest = componentsFunction.filterPaddingAndMargin(rest);\r\n return { ...newRest };\r\n };\r\n\r\n const handelScroll = (e) => {\r\n const dirRight = document.querySelector(\".cbmis-body-dir-rtl\") || dir === \"rtl\";\r\n const scrollStart = dirRight ? e.target.style.scrollRight : e.target.style.scrollLeft;\r\n const innerWidth = e.target.offsetWidth;\r\n const scrollWidth = e.target.scrollWidth;\r\n\r\n if (scrollStart + innerWidth >= scrollWidth) {\r\n document.querySelector(\".cbmis-tab-header-nav-next\").style.display = \"none\";\r\n } else {\r\n document.querySelector(\".cbmis-tab-header-nav-next\").style.display = \"block\";\r\n }\r\n if (scrollStart === 0) {\r\n document.querySelector(\".cbmis-tab-header-nav-prev\").style.display = \"none\";\r\n } else {\r\n document.querySelector(\".cbmis-tab-header-nav-prev\").style.display = \"block\";\r\n }\r\n };\r\n\r\n const handelNext = () => {\r\n const div = document.querySelector(\".cbmis-tabs\");\r\n div.scrollLeft += 200;\r\n };\r\n\r\n const handelPrev = () => {\r\n const div = document.querySelector(\".cbmis-tabs\");\r\n div.scrollLeft -= 200;\r\n };\r\n\r\n const getScroll = () => {\r\n const tabs = document.querySelector(\".cbmis-tabs\");\r\n const innerWidth = tabs.offsetWidth;\r\n const scrollWidth = tabs.scrollWidth;\r\n const dirRight = document.querySelector(\".cbmis-body-dir-rtl\") || dir === \"rtl\";\r\n if (dirRight) {\r\n if (Number(innerWidth) < Number(scrollWidth)) {\r\n document.querySelector(\".cbmis-tab-header-nav-prev\").style.display = \"block\";\r\n }\r\n } else {\r\n if (Number(innerWidth) < Number(scrollWidth)) {\r\n document.querySelector(\".cbmis-tab-header-nav-next\").style.display = \"block\";\r\n }\r\n }\r\n };\r\n\r\n return (\r\n \r\n
\r\n\r\n
\r\n {tabsContent.map((el, i) => (\r\n
\r\n
handleTabClicked(e, i, el)}\r\n />\r\n
\r\n \r\n {\r\n el?.head?(\r\n
{el?.head}
\r\n ):\"\"\r\n }\r\n {el.tabLabel}\r\n
\r\n \r\n
\r\n ))}\r\n
\r\n\r\n
\r\n\r\n
\r\n );\r\n}\r\n\r\nexport default TabsHead;\r\n","import React, { useEffect, useState, Fragment, useRef } from \"react\";\r\nimport * as componentsFunction from \"../../../helper/CbmisFunction\";\r\nimport useCheckScreenSize from \"../../../hook/useCheckScreenSize\";\r\nimport TabsHead from \"./TabsHead\";\r\nimport { setSxClassName } from \"../../../helper/convertJsCss\";\r\n\r\nfunction Tab(props) {\r\n const { tabsContent, currentTab, activeColor, mode, sx, hidden, disabled, dir, className, id, ...rest } = props;\r\n\r\n const screenWidth = useCheckScreenSize();\r\n\r\n const getID = useRef(id || componentsFunction.randomName(\"Tabs\"));\r\n const styleRef = useRef({ strSxClassName: \"\" });\r\n\r\n const [currentTabIndex, setCurrentTabIndex] = useState(0);\r\n const [tabsContentArr, setTabsContentArr] = useState([]);\r\n\r\n useEffect(() => {}, [tabsContent, currentTab, activeColor, mode, sx, hidden, disabled, dir, className, id]);\r\n\r\n useEffect(() => {\r\n if (currentTab && parseInt(currentTab) > 1) {\r\n setCurrentTabIndex(parseInt(currentTab) - 1);\r\n } else {\r\n setCurrentTabIndex(0);\r\n }\r\n }, [currentTab]);\r\n\r\n useEffect(() => {\r\n if (sx) {\r\n setSxClassName(styleRef, getID.current, sx, \"cbmis-tabs-container\");\r\n }\r\n }, [sx, screenWidth]);\r\n\r\n useEffect(() => {\r\n if (tabsContent) {\r\n setTabsContentArr(tabsContent || []);\r\n }\r\n }, [tabsContent]);\r\n\r\n const navigateTotabHandler = (index) => {\r\n if (index !== currentTabIndex) {\r\n setCurrentTabIndex(index);\r\n }\r\n };\r\n const getMode = (mode) => {\r\n switch (String(mode).toLowerCase()) {\r\n case \"nav\":\r\n return \"cbmis-tabs-container-mode-nav\";\r\n case \"box\":\r\n return \"cbmis-tabs-container-mode-box\";\r\n case \"pill\":\r\n return \"cbmis-tabs-container-mode-pill\";\r\n case \"vertical\":\r\n return \"cbmis-tabs-container-mode-vertical\";\r\n default:\r\n return \"cbmis-tabs-container-mode-nav\";\r\n }\r\n };\r\n\r\n // const getPosition=()=>{\r\n // \tswitch (String(mode).toLowerCase() === \"vertical\") {\r\n // \t\tcase \"end\":\r\n // \t\t return(\"cbmis-vertical-tab-position-end\")\r\n // \t\tcase \"top\":\r\n // \t\t return(\"cbmis-vertical-tab-position-top\")\r\n // \t\tcase \"bottom\":\r\n // \t\t return(\"cbmis-vertical-tab-position-bottom\")\r\n // \t\tcase \"start\":\r\n // \t\t\treturn(\"cbmis-vertical-tab-position-start\")\r\n // \t default:\r\n // \t\t return(\"cbmis-vertical-tab-Position-start\")\r\n // }\r\n // }\r\n\r\n return (\r\n \r\n
\r\n
\r\n {tabsContentArr.map((el, i) => (\r\n {i === currentTabIndex && el.content} \r\n ))}\r\n
\r\n
\r\n );\r\n}\r\n\r\nexport default Tab;\r\n","\n import API from \"!../../../../node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js\";\n import domAPI from \"!../../../../node_modules/style-loader/dist/runtime/styleDomAPI.js\";\n import insertFn from \"!../../../../node_modules/style-loader/dist/runtime/insertBySelector.js\";\n import setAttributes from \"!../../../../node_modules/style-loader/dist/runtime/setAttributesWithoutAttributes.js\";\n import insertStyleElement from \"!../../../../node_modules/style-loader/dist/runtime/insertStyleElement.js\";\n import styleTagTransformFn from \"!../../../../node_modules/style-loader/dist/runtime/styleTagTransform.js\";\n import content, * as namedExport from \"!!../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[1].use[1]!./ParallaxScrolling.css\";\n \n \n\nvar options = {};\n\noptions.styleTagTransform = styleTagTransformFn;\noptions.setAttributes = setAttributes;\n\n options.insert = insertFn.bind(null, \"head\");\n \noptions.domAPI = domAPI;\noptions.insertStyleElement = insertStyleElement;\n\nvar update = API(content, options);\n\n\n\nexport * from \"!!../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[1].use[1]!./ParallaxScrolling.css\";\n export default content && content.locals ? content.locals : undefined;\n","import React, { useEffect, useRef } from \"react\";\r\nimport \"./ParallaxScrolling.css\";\r\nimport \"../../../style/main.css\";\r\nimport * as componentsFunction from \"../../../helper/CbmisFunction\";\r\nimport useCheckScreenSize from \"../../../hook/useCheckScreenSize\";\r\nimport { setSxClassName } from \"../../../helper/convertJsCss\";\r\n\r\nfunction ParallaxScrolling(props) {\r\n const { src, id, sx, hidden, disabled, dir, className, ...rest } = props;\r\n\r\n const screenWidth = useCheckScreenSize();\r\n\r\n const getID = useRef(id || componentsFunction.randomName(\"Link\"));\r\n const styleRefContainer = useRef({ strSxClassName: \"\", strSXComponentID: componentsFunction.randomName(\"cbmis-ParallaxScrolling-container\") });\r\n const styleRefImg = useRef({ strSxClassName: \"\" });\r\n\r\n const getRestProps = () => {\r\n const newRest = componentsFunction.filterPaddingAndMargin(rest);\r\n return { ...newRest };\r\n };\r\n\r\n useEffect(() => {}, [src, id, hidden, disabled, dir, className]);\r\n\r\n useEffect(() => {\r\n if (sx) {\r\n setSxClassName(styleRefContainer, styleRefContainer.current.strSXComponentID, sx, \"cbmis-ParallaxScrolling-container\");\r\n setSxClassName(styleRefImg, getID.current, sx, \"cbmis-ParallaxScrolling-image\");\r\n }\r\n }, [sx, screenWidth]);\r\n\r\n return (\r\n \r\n
\r\n
{props.children}
\r\n
\r\n
\r\n );\r\n}\r\n\r\nexport default ParallaxScrolling;\r\n","\n import API from \"!../../../../node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js\";\n import domAPI from \"!../../../../node_modules/style-loader/dist/runtime/styleDomAPI.js\";\n import insertFn from \"!../../../../node_modules/style-loader/dist/runtime/insertBySelector.js\";\n import setAttributes from \"!../../../../node_modules/style-loader/dist/runtime/setAttributesWithoutAttributes.js\";\n import insertStyleElement from \"!../../../../node_modules/style-loader/dist/runtime/insertStyleElement.js\";\n import styleTagTransformFn from \"!../../../../node_modules/style-loader/dist/runtime/styleTagTransform.js\";\n import content, * as namedExport from \"!!../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[1].use[1]!./AppBar.css\";\n \n \n\nvar options = {};\n\noptions.styleTagTransform = styleTagTransformFn;\noptions.setAttributes = setAttributes;\n\n options.insert = insertFn.bind(null, \"head\");\n \noptions.domAPI = domAPI;\noptions.insertStyleElement = insertStyleElement;\n\nvar update = API(content, options);\n\n\n\nexport * from \"!!../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[1].use[1]!./AppBar.css\";\n export default content && content.locals ? content.locals : undefined;\n","const __WEBPACK_NAMESPACE_OBJECT__ = require(\"async\");","import React, { useEffect, useRef, useState } from \"react\";\r\nimport \"./AppBar.css\";\r\nimport Drawer from \"../Drawer/Drawer\";\r\nimport BottomBar from \"../BottomBar/BottomBar\";\r\nimport \"../../../style/main.css\";\r\nimport * as componentsFunction from \"../../../helper/CbmisFunction\";\r\nimport useCheckScreenSize from \"../../../hook/useCheckScreenSize\";\r\nimport { setSxClassName } from \"../../../helper/convertJsCss\";\r\nimport { log } from \"async\";\r\n\r\nfunction AppBar(props) {\r\n const {\r\n textColor,\r\n color,\r\n position,\r\n isClose,\r\n justify,\r\n sideBarMode,\r\n sideBarTitle,\r\n sideBarTextColor,\r\n sideBarColor,\r\n sideBarClose,\r\n sideBarPosition,\r\n sx,\r\n hidden,\r\n disabled,\r\n dir,\r\n className,\r\n id,\r\n ...rest\r\n } = props;\r\n\r\n const screenWidth = useCheckScreenSize();\r\n const getID = useRef(id || componentsFunction.randomName(\"AppBar\"));\r\n const styleRef = useRef({ strSxClassName: \"\" });\r\n\r\n var viewport_width = window.innerWidth;\r\n const [openMenu, setOpenMenu] = useState({\r\n sideBarOpen: false,\r\n bottomOpen: false,\r\n bottomBarContent: \"\",\r\n bottomBarTitle: \"\",\r\n });\r\n\r\n useEffect(() => {}, [position, isClose, hidden, disabled, dir, className, id]);\r\n\r\n useEffect(() => {\r\n if (sx) {\r\n setSxClassName(styleRef, getID.current, sx, \"cbmis-app-bar\");\r\n }\r\n }, [sx, screenWidth]);\r\n\r\n const bodyMarginTop = () => {\r\n document.body.style.paddingTop = \"5ram\";\r\n };\r\n\r\n const getPostion = () => {\r\n if (position) {\r\n const positionAppBar = String(position).toLowerCase();\r\n switch (positionAppBar) {\r\n case \"fixed\":\r\n bodyMarginTop();\r\n return \"cbmis-app-bar-position-fixed\";\r\n case \"relative\":\r\n return \"cbmis-app-bar-position-relative\";\r\n case \"static\":\r\n return \"cbmis-app-bar-position-static\";\r\n case \"absolute\":\r\n bodyMarginTop();\r\n return \"cbmis-app-bar-position-absolute\";\r\n case \"sticky\":\r\n return \"cbmis-app-bar-position-sticky\";\r\n default:\r\n return \"\";\r\n }\r\n }\r\n };\r\n\r\n const getJustify = () => {\r\n switch (String(justify).toLowerCase()) {\r\n case \"start\":\r\n return \"cbmis-toolbar-justify-self-flex-start\";\r\n case \"center\":\r\n return \"cbmis-toolbar-justify-self-center\";\r\n case \"end\":\r\n return \"cbmis-toolbar-justify-self-flex-end\";\r\n case \"space-between\":\r\n return \"cbmis-toolbar-justify-self-space-between\";\r\n case \"space-around\":\r\n return \"cbmis-toolbar-justify-self-space-around\";\r\n case \"space-evenly\":\r\n return \"cbmis-toolbar-justify-self-space-evenly\";\r\n default:\r\n return \"cbmis-toolbar-justify-self-space-between\";\r\n }\r\n };\r\n const getRestProps = () => {\r\n const newRest = componentsFunction.filterPaddingAndMargin(rest);\r\n return { ...newRest };\r\n };\r\n\r\n const handelDialogDrawer = () => {\r\n openMenu.sideBarOpen = !openMenu.sideBarOpen;\r\n setOpenMenu({ ...openMenu });\r\n };\r\n const handelDialogBottomMenu =(item = {}) =>\r\n () => {\r\n if (!openMenu.bottomOpen) {\r\n if (item?.props?.menu && String(item?.props?.ssMode).toLowerCase() === \"bottombar\" && viewport_width <= 800) {\r\n openMenu.bottomOpen = true;\r\n openMenu.bottomBarTitle = item?.props?.label;\r\n openMenu.bottomBarContent = item?.props?.menu || \"\";\r\n }\r\n } else {\r\n openMenu.bottomOpen = false;\r\n openMenu.bottomBarContent = \"\";\r\n openMenu.bottomBarTitle = \"\";\r\n }\r\n setOpenMenu({ ...openMenu });\r\n };\r\n\r\n const handelCloseBottomMenu = () => {\r\n openMenu.bottomOpen = false;\r\n openMenu.bottomBarContent = \"\";\r\n setOpenMenu({ ...openMenu });\r\n };\r\n\r\n const checkChildren = (propsChildren) => {\r\n let children = [];\r\n if (propsChildren) {\r\n if (Array.isArray(propsChildren)) {\r\n children = propsChildren;\r\n } else {\r\n children = [propsChildren];\r\n }\r\n }\r\n return children;\r\n };\r\n\r\n const getContent = () => {\r\n const children = checkChildren(props?.children);\r\n let navBar = [];\r\n let sideBar = [];\r\n let bottomBar = [];\r\n let logo = \"\";\r\n\r\n const checkMode = (mode, item, defaultItem) => {\r\n switch (String(mode).toLowerCase()) {\r\n case \"logo\":\r\n logo = item;\r\n break;\r\n case \"sidebar\":\r\n sideBar.push(item);\r\n break;\r\n case \"navbar\":\r\n navBar.push(item);\r\n break;\r\n case \"bottombar\":\r\n const bottomItem = {\r\n icon: item?.props?.icon,\r\n path: item?.props?.path,\r\n label: item.props?.label || item?.props?.children,\r\n onClick: handelDialogBottomMenu(item),\r\n };\r\n if (Number(item.props.bottomBarIndex)) {\r\n bottomBar[Number(item.props.bottomBarIndex)] = bottomItem;\r\n } else {\r\n bottomBar.push(bottomItem);\r\n }\r\n break;\r\n case \"none\":\r\n break;\r\n default:\r\n switch (String(defaultItem).toLowerCase()) {\r\n case \"sidebar\":\r\n sideBar.push(item);\r\n break;\r\n case \"navbar\":\r\n navBar.push(item);\r\n break;\r\n default:\r\n break;\r\n }\r\n break;\r\n }\r\n };\r\n\r\n children.forEach((item) => {\r\n const children2 = checkChildren(item?.props?.children);\r\n\r\n if (viewport_width > 800) {\r\n if (item.props.sxMode) {\r\n checkMode(item.props.sxMode, item, \"navbar\");\r\n } else {\r\n children2.forEach((child) => {\r\n checkMode(child.props.sxMode, child, \"sidebar\");\r\n });\r\n }\r\n } else {\r\n if (item.props.ssMode) {\r\n checkMode(item.props.ssMode, item);\r\n } else {\r\n children2.forEach((child) => {\r\n checkMode(child.props.ssMode, child);\r\n });\r\n }\r\n }\r\n });\r\n\r\n return [navBar, sideBar, bottomBar, logo];\r\n };\r\n\r\n useEffect(() => {\r\n if(sideBarClose === true && viewport_width < 800 ){\r\n handelDialogDrawer()\r\n }\r\n }, [sideBarClose])\r\n \r\n\r\n const [navBar, sideBar, bottomBar, logo] = getContent();\r\n\r\n return (\r\n \r\n \r\n {logo && String(sideBarMode).toLowerCase() !== \"show-header\" ? {logo}
: null}\r\n\r\n {sideBar.length && String(sideBarMode).toLowerCase() !== \"show-header\" ? (\r\n \r\n ) : null}\r\n {navBar}\r\n \r\n \r\n \r\n {logo && String(sideBarMode).toLowerCase() === \"show-header\" ?
{logo}
: null}\r\n {sideBar}\r\n
\r\n \r\n\r\n {viewport_width > 800 ? null : (\r\n \r\n {openMenu.bottomBarContent}
\r\n \r\n )}\r\n \r\n \r\n );\r\n}\r\n\r\nexport default AppBar;\r\n","\n import API from \"!../../../../node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js\";\n import domAPI from \"!../../../../node_modules/style-loader/dist/runtime/styleDomAPI.js\";\n import insertFn from \"!../../../../node_modules/style-loader/dist/runtime/insertBySelector.js\";\n import setAttributes from \"!../../../../node_modules/style-loader/dist/runtime/setAttributesWithoutAttributes.js\";\n import insertStyleElement from \"!../../../../node_modules/style-loader/dist/runtime/insertStyleElement.js\";\n import styleTagTransformFn from \"!../../../../node_modules/style-loader/dist/runtime/styleTagTransform.js\";\n import content, * as namedExport from \"!!../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[1].use[1]!./GroupBar.css\";\n \n \n\nvar options = {};\n\noptions.styleTagTransform = styleTagTransformFn;\noptions.setAttributes = setAttributes;\n\n options.insert = insertFn.bind(null, \"head\");\n \noptions.domAPI = domAPI;\noptions.insertStyleElement = insertStyleElement;\n\nvar update = API(content, options);\n\n\n\nexport * from \"!!../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[1].use[1]!./GroupBar.css\";\n export default content && content.locals ? content.locals : undefined;\n","import React, { useEffect, useRef } from \"react\";\r\nimport \"./GroupBar.css\";\r\nimport \"../../../style/main.css\";\r\nimport * as componentsFunction from \"../../../helper/CbmisFunction\";\r\nimport useCheckScreenSize from \"../../../hook/useCheckScreenSize\";\r\nimport { setSxClassName } from \"../../../helper/convertJsCss\";\r\n\r\nfunction GroupBar(props) {\r\n const { sx, hidden, disabled, dir, className, id, logoTextDir, color, pathPages, sxMode, ssMode, position, ...rest } = props;\r\n\r\n const screenWidth = useCheckScreenSize();\r\n const pathName = window.location.pathname;\r\n var viewport_width = window.innerWidth;\r\n\r\n const getID = useRef(id || componentsFunction.randomName(\"GroupBar\"));\r\n const styleRef = useRef({ strSxClassName: \"\" });\r\n\r\n useEffect(() => {}, [sx, hidden, disabled, dir, className, id, logoTextDir, pathPages]);\r\n\r\n useEffect(() => {\r\n if (styleRef.current.strSxClassName)\r\n if (color) {\r\n componentsFunction.getbgColorReturnClassName(\".\" + styleRef.current.strSxClassName, color);\r\n }\r\n }, [styleRef.current.strSxClassName]);\r\n\r\n useEffect(() => {\r\n if (sx) {\r\n setSxClassName(styleRef, getID.current, sx, \"cbmis-groupBar\");\r\n }\r\n }, [sx, screenWidth]);\r\n\r\n const getLogoTextDirection = () => {\r\n switch (String(logoTextDir).toLowerCase()) {\r\n case \"end\":\r\n return \"cbmis-logo-Text-direction-end\";\r\n case \"start\":\r\n return \"cbmis-logo-Text-direction-start\";\r\n case \"bottom\":\r\n return \"cbmis-logo-Text-direction-bottom\";\r\n case \"top\":\r\n return \"cbmis-logo-Text-direction-top\";\r\n default:\r\n return \"cbmis-logo-Text-direction-end\";\r\n }\r\n };\r\n\r\n const getPosition = () => {\r\n switch (String(position).toLowerCase()) {\r\n case \"end\":\r\n return \"cbmis-position-groupbar-appbar-end\";\r\n case \"start\":\r\n return \"cbmis-position-groupbar-appbar-start\";\r\n default:\r\n return \"cbmis-Position-default\";\r\n }\r\n };\r\n\r\n const getViewToolBar = () => {\r\n if (pathPages && pathPages.length) {\r\n const path = pathPages.filter((item) => item === pathName);\r\n if (path[0]) {\r\n return true;\r\n } else {\r\n return false;\r\n }\r\n }\r\n return true;\r\n };\r\n\r\n return getViewToolBar() ? (\r\n 800) || (String(ssMode).toLowerCase() === \"sidebar\" && viewport_width <= 800)\r\n ? \"cbmis-appbar-toolbar-menu\"\r\n : \"\"\r\n } \r\n ${componentsFunction.CheckDisabledItem(disabled)} \r\n ${componentsFunction.CheckHiddenItem(hidden)} \r\n ${componentsFunction.checkExistsMargin(rest)} \r\n ${componentsFunction.checkExistsPadding(rest)}\r\n ${componentsFunction.CheckDirectionItem(dir)} \r\n ${className || \"\"}`}\r\n id={getID.current}\r\n key={getID.current}\r\n >\r\n {props.children}\r\n
\r\n ) : (\r\n \"\"\r\n );\r\n}\r\n\r\nexport default GroupBar;\r\n","\n import API from \"!../../../../node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js\";\n import domAPI from \"!../../../../node_modules/style-loader/dist/runtime/styleDomAPI.js\";\n import insertFn from \"!../../../../node_modules/style-loader/dist/runtime/insertBySelector.js\";\n import setAttributes from \"!../../../../node_modules/style-loader/dist/runtime/setAttributesWithoutAttributes.js\";\n import insertStyleElement from \"!../../../../node_modules/style-loader/dist/runtime/insertStyleElement.js\";\n import styleTagTransformFn from \"!../../../../node_modules/style-loader/dist/runtime/styleTagTransform.js\";\n import content, * as namedExport from \"!!../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[1].use[1]!./Nav.css\";\n \n \n\nvar options = {};\n\noptions.styleTagTransform = styleTagTransformFn;\noptions.setAttributes = setAttributes;\n\n options.insert = insertFn.bind(null, \"head\");\n \noptions.domAPI = domAPI;\noptions.insertStyleElement = insertStyleElement;\n\nvar update = API(content, options);\n\n\n\nexport * from \"!!../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[1].use[1]!./Nav.css\";\n export default content && content.locals ? content.locals : undefined;\n","import React, { useEffect, useRef, useState } from \"react\";\r\nimport \"./Nav.css\";\r\nimport Badge from \"../../dataDisplay/Badge/Badge\";\r\nimport { useNavigate } from \"react-router-dom\";\r\nimport Avatar from \"../../dataDisplay/Avatar/Avatar\";\r\nimport Typography from \"../../dataDisplay/Typography/Typography\";\r\nimport Icon from \"../../../icon/CbmisIcon\";\r\nimport \"../../../style/main.css\";\r\nimport * as componentsFunction from \"../../../helper/CbmisFunction\";\r\nimport useCheckScreenSize from \"../../../hook/useCheckScreenSize\";\r\nimport { setSxClassName } from \"../../../helper/convertJsCss\";\r\n\r\nconst Nav = (props) => {\r\n const {\r\n label,\r\n path,\r\n menu,\r\n id,\r\n badge,\r\n color,\r\n textColor,\r\n headItem,\r\n headItemPosition,\r\n footerItem,\r\n icon,\r\n iconColor,\r\n iconSize,\r\n sx,\r\n hidden,\r\n disabled,\r\n dir,\r\n className,\r\n ...rest\r\n } = props;\r\n\r\n const screenWidth = useCheckScreenSize();\r\n\r\n const navigate = useNavigate();\r\n const pathName = window.location.pathname;\r\n\r\n const getID = useRef(id || componentsFunction.randomName(\"AppBarNav\"));\r\n const styleRef = useRef({ strSxClassName: \"\", strSXComponentID: componentsFunction.randomName(\"cbmis-nav\") });\r\n\r\n const [stateInfo, setStateInfo] = useState({\r\n isParentGrawerShowHeader: false,\r\n index: 1,\r\n selected: path === pathName ? \"cbmis-app-bar-nav-selected\" : \"\",\r\n });\r\n\r\n useEffect(() => {\r\n if (sx) {\r\n setSxClassName(styleRef, styleRef.current.strSXComponentID, sx, \"cbmis-nav\");\r\n }\r\n }, [sx, screenWidth]);\r\n\r\n const handelLinlPathGo = () => {\r\n if (path) {\r\n if (String(path)[0] === \"#\" || String(path)[0] === \".\") {\r\n if (String(path).length > 1) componentsFunction.scrollToElement(path);\r\n } else if (path && (String(path).toLowerCase().includes(\".com\") || String(path).toLowerCase().includes(\"http\"))) {\r\n window.open(`${path}`, \"_blank\", true);\r\n } else if (path && (String(path).toLowerCase() === \"back\" || String(path).toLowerCase() === \"-1\")) {\r\n navigate(-1);\r\n } else if (path) {\r\n navigate(path);\r\n }\r\n }\r\n\r\n var element = document.querySelector(\".cbmis-app-bar-side-bar-open\");\r\n if (element && !menu) {\r\n element.classList.remove(\"cbmis-app-bar-side-bar-open\");\r\n }\r\n const selectedNav = document.querySelectorAll(\".cbmis-app-bar-nav-selected\");\r\n selectedNav.forEach((item) => {\r\n item.classList.remove(\"cbmis-app-bar-nav-selected\");\r\n });\r\n stateInfo.selected = \"cbmis-app-bar-nav-selected\";\r\n setStateInfo({ ...stateInfo });\r\n };\r\n\r\n const getRestProps = () => {\r\n const newRest = componentsFunction.filterPaddingAndMargin(rest);\r\n return { ...newRest };\r\n };\r\n\r\n const getHeadItemPosition = () => {\r\n switch (String(headItemPosition).toLowerCase()) {\r\n case \"end\":\r\n return \"cbmis-head-Item-Position-end\";\r\n case \"start\":\r\n return \"cbmis-head-Item-Position-start\";\r\n case \"bottom\":\r\n return \"cbmis-head-Item-Position-bottom\";\r\n case \"top\":\r\n return \"cbmis-head-Item-Position-top\";\r\n default:\r\n return \"cbmis-head-Item-Position-start\";\r\n }\r\n };\r\n\r\n const navContentJXS = (\r\n \r\n \r\n {headItem ? (\r\n headItem\r\n ) : icon ? (\r\n \r\n ) : stateInfo.isParentGrawerShowHeader ? (\r\n \r\n \r\n {stateInfo.index}\r\n \r\n \r\n ) : null}\r\n \r\n {label || props.children} \r\n {footerItem} \r\n \r\n );\r\n\r\n useEffect(() => {\r\n const child = document.getElementById(getID.current);\r\n stateInfo.isParentGrawerShowHeader = child.closest(\".cbmis-drawer-show-header\") !== null;\r\n stateInfo.index = Array.from(child.parentElement.children).indexOf(child);\r\n setStateInfo({ ...stateInfo });\r\n }, []);\r\n\r\n return (\r\n \r\n \r\n {badge ? (\r\n \r\n {navContentJXS}\r\n \r\n ) : (\r\n navContentJXS\r\n )}\r\n {menu ? (\r\n \r\n
\r\n {menu.map((item, index) => {\r\n return {item} ;\r\n })}\r\n \r\n
\r\n ) : null}\r\n \r\n \r\n );\r\n};\r\n\r\nexport default Nav;\r\n","\n import API from \"!../../../../node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js\";\n import domAPI from \"!../../../../node_modules/style-loader/dist/runtime/styleDomAPI.js\";\n import insertFn from \"!../../../../node_modules/style-loader/dist/runtime/insertBySelector.js\";\n import setAttributes from \"!../../../../node_modules/style-loader/dist/runtime/setAttributesWithoutAttributes.js\";\n import insertStyleElement from \"!../../../../node_modules/style-loader/dist/runtime/insertStyleElement.js\";\n import styleTagTransformFn from \"!../../../../node_modules/style-loader/dist/runtime/styleTagTransform.js\";\n import content, * as namedExport from \"!!../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[1].use[1]!./BtnGoToTop.css\";\n \n \n\nvar options = {};\n\noptions.styleTagTransform = styleTagTransformFn;\noptions.setAttributes = setAttributes;\n\n options.insert = insertFn.bind(null, \"head\");\n \noptions.domAPI = domAPI;\noptions.insertStyleElement = insertStyleElement;\n\nvar update = API(content, options);\n\n\n\nexport * from \"!!../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[1].use[1]!./BtnGoToTop.css\";\n export default content && content.locals ? content.locals : undefined;\n","import React, { useEffect, useRef, useState } from \"react\";\r\nimport \"./BtnGoToTop.css\";\r\nimport \"../../../style/main.css\";\r\nimport CbmisIcon from \"../../../icon/CbmisIcon\";\r\nimport * as componentsFunction from \"../../../helper/CbmisFunction\";\r\nimport useCheckScreenSize from \"../../../hook/useCheckScreenSize\";\r\nimport { setSxClassName } from \"../../../helper/convertJsCss\";\r\n\r\nconst BtnGoToTop = (props) => {\r\n const { icon, color, iconColor, position, sx, hidden, disabled, dir, className, id, onClick, ...rest } = props;\r\n\r\n const screenWidth = useCheckScreenSize();\r\n\r\n const getID = useRef(id || componentsFunction.randomName(\"BtnGoToTop\"));\r\n const [showButton, setShowButton] = useState(false);\r\n const styleRef = useRef({ strSxClassName: \"\" });\r\n\r\n useEffect(() => {}, [icon, iconColor, sx, hidden, disabled, dir, className, id, onClick]);\r\n\r\n useEffect(() => {\r\n if (color && styleRef.current.strSxClassName) {\r\n componentsFunction.getbgColorReturnClassName(\".\" + styleRef.current.strSxClassName, color || \"#000000cf\");\r\n }\r\n // eslint-disable-next-line react-hooks/exhaustive-deps\r\n }, [color]);\r\n\r\n useEffect(() => {\r\n const handleScroll = () => {\r\n if (window.scrollY > window.innerHeight) {\r\n setShowButton(true);\r\n } else {\r\n setShowButton(false);\r\n }\r\n };\r\n window.addEventListener(\"scroll\", handleScroll);\r\n //clean up\r\n return () => {\r\n window.removeEventListener(\"scroll\", handleScroll);\r\n };\r\n }, []);\r\n\r\n useEffect(() => {\r\n if (sx) {\r\n setSxClassName(styleRef, getID.current, sx, \"cbmisToTopButton\");\r\n }\r\n }, [sx, screenWidth]);\r\n\r\n const scrollToTop = () => {\r\n window.scrollTo({\r\n top: 0,\r\n behavior: \"smooth\",\r\n });\r\n };\r\n\r\n const handleClicked = () => {\r\n if (onClick) {\r\n onClick();\r\n }\r\n scrollToTop();\r\n };\r\n\r\n const getPosition = () => {\r\n switch (String(position).toLowerCase()) {\r\n case \"left\":\r\n return \"cbmisToTopButton-position-left\";\r\n default:\r\n return \"\";\r\n }\r\n };\r\n\r\n const getRestProps = () => {\r\n const newRest = componentsFunction.filterPaddingAndMargin(rest);\r\n return { ...newRest };\r\n };\r\n\r\n return (\r\n showButton && (\r\n \r\n \r\n \r\n )\r\n );\r\n};\r\n\r\nexport default BtnGoToTop;\r\n","\n import API from \"!../../../../node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js\";\n import domAPI from \"!../../../../node_modules/style-loader/dist/runtime/styleDomAPI.js\";\n import insertFn from \"!../../../../node_modules/style-loader/dist/runtime/insertBySelector.js\";\n import setAttributes from \"!../../../../node_modules/style-loader/dist/runtime/setAttributesWithoutAttributes.js\";\n import insertStyleElement from \"!../../../../node_modules/style-loader/dist/runtime/insertStyleElement.js\";\n import styleTagTransformFn from \"!../../../../node_modules/style-loader/dist/runtime/styleTagTransform.js\";\n import content, * as namedExport from \"!!../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[1].use[1]!./Accordion.css\";\n \n \n\nvar options = {};\n\noptions.styleTagTransform = styleTagTransformFn;\noptions.setAttributes = setAttributes;\n\n options.insert = insertFn.bind(null, \"head\");\n \noptions.domAPI = domAPI;\noptions.insertStyleElement = insertStyleElement;\n\nvar update = API(content, options);\n\n\n\nexport * from \"!!../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[1].use[1]!./Accordion.css\";\n export default content && content.locals ? content.locals : undefined;\n","import React, { useEffect, useRef } from \"react\";\r\nimport \"./Accordion.css\";\r\nimport * as componentsFunction from \"../../../helper/CbmisFunction\";\r\nimport useCheckScreenSize from \"../../../hook/useCheckScreenSize\";\r\nimport { setSxClassName } from \"../../../helper/convertJsCss\";\r\nimport { strTestProps } from \"../../../helper/CbmisVariables\";\r\n\r\nconst Accordion = (props) => {\r\n const { children, ariaControl, sx, hidden, disabled, dir, className, id,mode, ...rest } = props;\r\n const screenWidth = useCheckScreenSize();\r\n\r\n const getID = useRef(id || componentsFunction.randomName(\"Accordion\"));\r\n const styleRef = useRef({ strSxClassName: \"\", strSXComponentID: id || componentsFunction.randomName(\"cbmis-accordion-tabs\") });\r\n\r\n if(props?.[strTestProps]){\r\n if(children){\r\n console.log(\"Accordion\", \"children\");\r\n }\r\n if(props?.ariaControl){\r\n console.log(\"Accordion\", \"ariaControl\");\r\n }\r\n if(props?.sx){\r\n console.log(\"Accordion\", \"sx\",);\r\n }\r\n }\r\n const getRestProps = () => {\r\n const newRest = componentsFunction.filterPaddingAndMargin(rest);\r\n return { ...newRest };\r\n };\r\n\r\n useEffect(() => {}, [children, ariaControl, hidden, disabled, dir, className, id]);\r\n\r\n useEffect(() => {\r\n if (sx) {\r\n setSxClassName(styleRef, styleRef.current.strSXComponentID, sx, \"cbmis-accordion-tabs\");\r\n }\r\n }, [sx, screenWidth]);\r\n\r\n return (\r\n \r\n
\r\n
\r\n {children}\r\n
\r\n
\r\n
\r\n );\r\n};\r\n\r\nexport default Accordion;\r\n","import React, { useEffect, useRef } from \"react\";\r\nimport \"./Accordion.css\";\r\nimport * as componentsFunction from \"../../../helper/CbmisFunction\";\r\nimport useCheckScreenSize from \"../../../hook/useCheckScreenSize\";\r\nimport { setSxClassName } from \"../../../helper/convertJsCss\";\r\nimport { strTestProps } from \"../../../helper/CbmisVariables\";\r\n\r\nconst AccordionTab = (props) => {\r\n const { children, sx, hidden, disabled, dir, className, id, ...rest } = props;\r\n const screenWidth = useCheckScreenSize();\r\n\r\n if(props?.[strTestProps]){\r\n if(children){\r\n console.log(\"AccordionTab\", \"children\");\r\n }\r\n if(props?.sx){\r\n console.log(\"AccordionTab\", \"sx\",);\r\n }\r\n }\r\n const getID = useRef(id || componentsFunction.randomName(\"AvataAccordionTabr\"));\r\n const styleRef = useRef({ strSxClassName: \"\" });\r\n\r\n const getRestProps = () => {\r\n const newRest = componentsFunction.filterPaddingAndMargin(rest);\r\n return { ...newRest };\r\n };\r\n\r\n useEffect(() => {}, [children, hidden, disabled, dir, className, id]);\r\n\r\n useEffect(() => {\r\n if (sx) {\r\n setSxClassName(styleRef, getID.current, sx, \"cbmis-accordion-tab-summary\");\r\n }\r\n }, [sx, screenWidth]);\r\n\r\n return (\r\n \r\n {children}\r\n
\r\n );\r\n};\r\n\r\nexport default AccordionTab;\r\n","import React, { useEffect, useRef, useState } from \"react\";\r\nimport \"./Accordion.css\";\r\nimport * as componentsFunction from \"../../../helper/CbmisFunction\";\r\nimport useCheckScreenSize from \"../../../hook/useCheckScreenSize\";\r\nimport { setSxClassName } from \"../../../helper/convertJsCss\";\r\nimport { strTestProps } from \"../../../helper/CbmisVariables\";\r\n\r\nconst AccordionSummary = (props) => {\r\n const { children, id, expandIcon, open = false, blnOpenOne = false, arrowIcon = true, sx, hidden, disabled, dir, className, ...rest } = props;\r\n\r\n if(props?.[strTestProps]){\r\n if(children){\r\n console.log(\"AccordionSummary\", \"children\");\r\n }\r\n if(props?.expandIcon){\r\n console.log(\"AccordionSummary\", \"expandIcon\",);\r\n }\r\n if(props?.blnOpenOne){\r\n console.log(\"AccordionSummary\", \"blnOpenOne\",);\r\n }\r\n if(props?.arrowIcon){\r\n console.log(\"AccordionSummary\", \"arrowIcon\",);\r\n }\r\n }\r\n\r\n const screenWidth = useCheckScreenSize();\r\n\r\n const [ariaControlName, setAriaControlName] = useState(\"accordionSummaryInput\");\r\n const getID = useRef(id || componentsFunction.randomName(\"AccordionSummary\"));\r\n const styleRef = useRef({ strSxClassName: \"\", strSXComponentID: componentsFunction.randomName(\"cbmis-accordion-tab-summary\") });\r\n\r\n useEffect(() => {}, [children, id, expandIcon, open, arrowIcon, hidden, disabled, dir, className]);\r\n\r\n useEffect(() => {\r\n if (sx) {\r\n setSxClassName(styleRef, styleRef.current.strSXComponentID, sx, \"cbmis-accordion-tab-summary\");\r\n }\r\n }, [sx, screenWidth]);\r\n\r\n useEffect(() => {\r\n const attribute = componentsFunction.checkParseObject(document.querySelector(\".cbmis-accordion-tabs\").attributes[2].value);\r\n if (attribute.ariaControl) {\r\n setAriaControlName(attribute.ariaControl);\r\n }\r\n }, []);\r\n\r\n const getRestProps = () => {\r\n const newRest = componentsFunction.filterPaddingAndMargin(rest);\r\n return { ...newRest };\r\n };\r\n\r\n return (\r\n \r\n \r\n \r\n \r\n {expandIcon} \r\n {children} \r\n \r\n \r\n \r\n );\r\n};\r\n\r\nexport default AccordionSummary;\r\n","import React, { useEffect, useRef } from \"react\";\r\nimport \"./Accordion.css\";\r\nimport * as componentsFunction from \"../../../helper/CbmisFunction\";\r\nimport useCheckScreenSize from \"../../../hook/useCheckScreenSize\";\r\nimport { setSxClassName } from \"../../../helper/convertJsCss\";\r\nimport { strTestProps } from \"../../../helper/CbmisVariables\";\r\n\r\nconst AccordionDetails = (props) => {\r\n const { children, hidden, sx, disabled, dir, className, id, ...rest } = props;\r\n\r\n const screenWidth = useCheckScreenSize();\r\n\r\n if(props?.[strTestProps]){\r\n if(children){\r\n console.log(\"AccordionDetails\", \"children\");\r\n }\r\n if(props?.sx){\r\n console.log(\"AccordionDetails\", \"sx\",);\r\n }\r\n }\r\n const getID = useRef(id || componentsFunction.randomName(\"AccordionDetails\"));\r\n const styleRef = useRef({ strSxClassName: \"\" });\r\n\r\n const getRestProps = () => {\r\n const newRest = componentsFunction.filterPaddingAndMargin(rest);\r\n return { ...newRest };\r\n };\r\n\r\n useEffect(() => {}, [children, hidden, disabled, dir, className, id]);\r\n\r\n useEffect(() => {\r\n if (sx) {\r\n setSxClassName(styleRef, getID.current, sx, \"cbmis-accordion-tab-details\");\r\n }\r\n }, [sx, screenWidth]);\r\n\r\n return (\r\n \r\n {children}\r\n
\r\n );\r\n};\r\n\r\nexport default AccordionDetails;\r\n","\n import API from \"!../../../../node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js\";\n import domAPI from \"!../../../../node_modules/style-loader/dist/runtime/styleDomAPI.js\";\n import insertFn from \"!../../../../node_modules/style-loader/dist/runtime/insertBySelector.js\";\n import setAttributes from \"!../../../../node_modules/style-loader/dist/runtime/setAttributesWithoutAttributes.js\";\n import insertStyleElement from \"!../../../../node_modules/style-loader/dist/runtime/insertStyleElement.js\";\n import styleTagTransformFn from \"!../../../../node_modules/style-loader/dist/runtime/styleTagTransform.js\";\n import content, * as namedExport from \"!!../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[1].use[1]!./Card.css\";\n \n \n\nvar options = {};\n\noptions.styleTagTransform = styleTagTransformFn;\noptions.setAttributes = setAttributes;\n\n options.insert = insertFn.bind(null, \"head\");\n \noptions.domAPI = domAPI;\noptions.insertStyleElement = insertStyleElement;\n\nvar update = API(content, options);\n\n\n\nexport * from \"!!../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[1].use[1]!./Card.css\";\n export default content && content.locals ? content.locals : undefined;\n","import React, { useEffect, useRef, useState } from \"react\";\r\nimport \"./Card.css\";\r\nimport \"../../../style/main.css\";\r\nimport * as componentsFunction from \"../../../helper/CbmisFunction\";\r\nimport useCheckScreenSize from \"../../../hook/useCheckScreenSize\";\r\nimport { setSxClassName } from \"../../../helper/convertJsCss\";\r\nimport { strTestProps } from \"../../../helper/CbmisVariables\";\r\n\r\nconst Card = (props) => {\r\n const { sx, hidden, disabled, dir, className, id, ...rest } = props;\r\n const screenWidth = useCheckScreenSize();\r\n\r\n if(props?.[strTestProps]){\r\n if(props?.sx){\r\n console.log(\"Card\", \"sx\",);\r\n }\r\n }\r\n const [haveBack, setHaveBack] = useState(true);\r\n const getID = useRef(id || componentsFunction.randomName(\"Card\"));\r\n const styleRef = useRef({ strSxClassName: \"\", strSXComponentID: componentsFunction.randomName(\"cbmis-card\") });\r\n\r\n useEffect(() => {}, [props.children, hidden, disabled, dir, className, id]);\r\n\r\n useEffect(() => {\r\n if (props.children) {\r\n setHaveBack(props.children[1] ? true : false);\r\n }\r\n }, []);\r\n\r\n useEffect(() => {\r\n if (sx) {\r\n setSxClassName(styleRef, styleRef.current.strSXComponentID, sx, \"cbmis-card\");\r\n }\r\n }, [sx, screenWidth]);\r\n\r\n const getRestProps = () => {\r\n const newRest = componentsFunction.filterPaddingAndMargin(rest);\r\n return { ...newRest };\r\n };\r\n\r\n return (\r\n \r\n
\r\n {props.children}\r\n
\r\n
\r\n );\r\n};\r\n\r\nexport default Card;\r\n","import React, { useEffect, useRef } from \"react\";\r\nimport \"./Card.css\";\r\nimport \"../../../style/main.css\";\r\nimport * as componentsFunction from \"../../../helper/CbmisFunction\";\r\nimport useCheckScreenSize from \"../../../hook/useCheckScreenSize\";\r\nimport { setSxClassName } from \"../../../helper/convertJsCss\";\r\nimport { strTestProps } from \"../../../helper/CbmisVariables\";\r\n\r\nconst CardFront = (props) => {\r\n const { sx, hidden, disabled, dir, className, id, ...rest } = props;\r\n\r\n if(props?.[strTestProps]){\r\n if(props?.sx){\r\n console.log(\"CardFront\", \"sx\",);\r\n }\r\n }\r\n const screenWidth = useCheckScreenSize();\r\n\r\n const getID = useRef(id || componentsFunction.randomName(\"CardFront\"));\r\n const styleRef = useRef({ strSxClassName: \"\" });\r\n\r\n const getRestProps = () => {\r\n const newRest = componentsFunction.filterPaddingAndMargin(rest);\r\n return { ...newRest };\r\n };\r\n\r\n useEffect(() => {}, [hidden, disabled, dir, className, id]);\r\n\r\n useEffect(() => {\r\n if (sx) {\r\n setSxClassName(styleRef, getID.current, sx, \"cbmis-card-front\");\r\n }\r\n }, [sx, screenWidth]);\r\n\r\n return (\r\n \r\n
{props.children}
\r\n
\r\n );\r\n};\r\n\r\nexport default CardFront;\r\n","import React, { useEffect, useRef } from \"react\";\r\nimport \"./Card.css\";\r\nimport \"../../../style/main.css\";\r\nimport * as componentsFunction from \"../../../helper/CbmisFunction\";\r\nimport useCheckScreenSize from \"../../../hook/useCheckScreenSize\";\r\nimport { setSxClassName } from \"../../../helper/convertJsCss\";\r\nimport { strTestProps } from \"../../../helper/CbmisVariables\";\r\n\r\nconst CardBack = (props) => {\r\n const { sx, hidden, disabled, dir, className, id, ...rest } = props;\r\n const screenWidth = useCheckScreenSize();\r\n\r\n if(props?.[strTestProps]){\r\n if(props?.sx){\r\n console.log(\"CardBack\", \"sx\",);\r\n }\r\n }\r\n const getID = useRef(id || componentsFunction.randomName(\"CardBack\"));\r\n const styleRef = useRef({ strSxClassName: \"\" });\r\n\r\n const getRestProps = () => {\r\n const newRest = componentsFunction.filterPaddingAndMargin(rest);\r\n return { ...newRest };\r\n };\r\n\r\n useEffect(() => {}, [hidden, disabled, dir, className, id]);\r\n\r\n useEffect(() => {\r\n if (sx) {\r\n setSxClassName(styleRef, getID.current, sx, \"cbmis-card-back\");\r\n }\r\n }, [sx, screenWidth]);\r\n\r\n return (\r\n \r\n
{props.children}
\r\n
\r\n );\r\n};\r\n\r\nexport default CardBack;\r\n","import React, { useEffect, useRef } from \"react\";\r\nimport \"./Card.css\";\r\nimport \"../../../style/main.css\";\r\nimport * as componentsFunction from \"../../../helper/CbmisFunction\";\r\nimport useCheckScreenSize from \"../../../hook/useCheckScreenSize\";\r\nimport { setSxClassName } from \"../../../helper/convertJsCss\";\r\nimport { strTestProps } from \"../../../helper/CbmisVariables\";\r\n\r\nconst CardImage = (props) => {\r\n const { src, title, hoverContent, sx, hidden, disabled, dir, className, id, ...rest } = props;\r\n const screenWidth = useCheckScreenSize();\r\n\r\n if(props?.[strTestProps]){\r\n if(props?.src){\r\n console.log(\"CardImage\", \"src\",);\r\n }\r\n if(props?.title){\r\n console.log(\"CardImage\", \"title\",);\r\n }\r\n if(props?.hoverContent){\r\n console.log(\"CardImage\", \"hoverContent\",);\r\n }\r\n if(props?.sx){\r\n console.log(\"CardImage\", \"sx\",);\r\n }\r\n }\r\n const getID = useRef(id || componentsFunction.randomName(\"CardImage\"));\r\n const styleRef = useRef({ strSxClassName: \"\" });\r\n\r\n const getRestProps = () => {\r\n const newRest = componentsFunction.filterPaddingAndMargin(rest);\r\n return { ...newRest };\r\n };\r\n\r\n useEffect(() => {}, [src, title, hoverContent, hidden, disabled, dir, className, id]);\r\n\r\n useEffect(() => {\r\n if (sx) {\r\n setSxClassName(styleRef, getID.current, sx, \"cbmis-card-image\");\r\n }\r\n }, [sx, screenWidth]);\r\n\r\n return (\r\n \r\n
{props.children}
\r\n
\r\n
\r\n
{hoverContent}
\r\n
\r\n
\r\n );\r\n};\r\n\r\nexport default CardImage;\r\n","import React, { useEffect, useRef } from \"react\";\r\nimport \"./Card.css\";\r\nimport \"../../../style/main.css\";\r\nimport * as componentsFunction from \"../../../helper/CbmisFunction\";\r\nimport useCheckScreenSize from \"../../../hook/useCheckScreenSize\";\r\nimport { setSxClassName } from \"../../../helper/convertJsCss\";\r\nimport { strTestProps } from \"../../../helper/CbmisVariables\";\r\n\r\nconst CardDetails = (props) => {\r\n const { sx, hidden, disabled, dir, className, id, ...rest } = props;\r\n const screenWidth = useCheckScreenSize();\r\n\r\n if(props?.[strTestProps]){\r\n if(props?.sx){\r\n console.log(\"CardDetails\", \"sx\",);\r\n }\r\n }\r\n const getID = useRef(id || componentsFunction.randomName(\"CardDetails\"));\r\n const styleRef = useRef({ strSxClassName: \"\" });\r\n\r\n const getRestProps = () => {\r\n const newRest = componentsFunction.filterPaddingAndMargin(rest);\r\n return { ...newRest };\r\n };\r\n\r\n useEffect(() => {}, [hidden, disabled, dir, className, id]);\r\n\r\n useEffect(() => {\r\n if (sx) {\r\n setSxClassName(styleRef, getID.current, sx, \"cbmis-card-details\");\r\n }\r\n }, [sx, screenWidth]);\r\n\r\n return (\r\n \r\n
{props.children}
\r\n
\r\n );\r\n};\r\n\r\nexport default CardDetails;\r\n","\n import API from \"!../../../../node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js\";\n import domAPI from \"!../../../../node_modules/style-loader/dist/runtime/styleDomAPI.js\";\n import insertFn from \"!../../../../node_modules/style-loader/dist/runtime/insertBySelector.js\";\n import setAttributes from \"!../../../../node_modules/style-loader/dist/runtime/setAttributesWithoutAttributes.js\";\n import insertStyleElement from \"!../../../../node_modules/style-loader/dist/runtime/insertStyleElement.js\";\n import styleTagTransformFn from \"!../../../../node_modules/style-loader/dist/runtime/styleTagTransform.js\";\n import content, * as namedExport from \"!!../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[1].use[1]!./Glass.css\";\n \n \n\nvar options = {};\n\noptions.styleTagTransform = styleTagTransformFn;\noptions.setAttributes = setAttributes;\n\n options.insert = insertFn.bind(null, \"head\");\n \noptions.domAPI = domAPI;\noptions.insertStyleElement = insertStyleElement;\n\nvar update = API(content, options);\n\n\n\nexport * from \"!!../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[1].use[1]!./Glass.css\";\n export default content && content.locals ? content.locals : undefined;\n","import React, { useEffect, useRef } from \"react\";\r\nimport \"./Glass.css\";\r\nimport \"../../../style/main.css\";\r\nimport * as componentsFunction from \"../../../helper/CbmisFunction\";\r\nimport useCheckScreenSize from \"../../../hook/useCheckScreenSize\";\r\nimport { setSxClassName } from \"../../../helper/convertJsCss\";\r\n\r\nconst Glass = (props) => {\r\n const { color, sx, hidden, disabled, dir, className, id, ...rest } = props;\r\n\r\n const screenWidth = useCheckScreenSize();\r\n const styleRef = useRef({ strSxClassName: \"\", strSXComponentID: id || componentsFunction.randomName(\"cbmis-glass\") });\r\n\r\n useEffect(() => {}, [hidden, disabled, dir, className, id]);\r\n\r\n useEffect(() => {\r\n document.documentElement.style.setProperty(\"--cbmis-glass-color\", componentsFunction.checkColorReturnValue(color || \"#000\"));\r\n }, [color]);\r\n\r\n useEffect(() => {\r\n if (sx) {\r\n setSxClassName(styleRef, styleRef.current.strSXComponentID, sx, \"cbmis-glass\");\r\n }\r\n }, [sx, screenWidth]);\r\n\r\n const getRestProps = () => {\r\n const newRest = componentsFunction.filterPaddingAndMargin(rest);\r\n return { ...newRest };\r\n };\r\n\r\n return (\r\n \r\n {props.children}\r\n
\r\n );\r\n};\r\n\r\nexport default Glass;\r\n","\n import API from \"!../../../../node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js\";\n import domAPI from \"!../../../../node_modules/style-loader/dist/runtime/styleDomAPI.js\";\n import insertFn from \"!../../../../node_modules/style-loader/dist/runtime/insertBySelector.js\";\n import setAttributes from \"!../../../../node_modules/style-loader/dist/runtime/setAttributesWithoutAttributes.js\";\n import insertStyleElement from \"!../../../../node_modules/style-loader/dist/runtime/insertStyleElement.js\";\n import styleTagTransformFn from \"!../../../../node_modules/style-loader/dist/runtime/styleTagTransform.js\";\n import content, * as namedExport from \"!!../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[1].use[1]!./Paper.css\";\n \n \n\nvar options = {};\n\noptions.styleTagTransform = styleTagTransformFn;\noptions.setAttributes = setAttributes;\n\n options.insert = insertFn.bind(null, \"head\");\n \noptions.domAPI = domAPI;\noptions.insertStyleElement = insertStyleElement;\n\nvar update = API(content, options);\n\n\n\nexport * from \"!!../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[1].use[1]!./Paper.css\";\n export default content && content.locals ? content.locals : undefined;\n","/* eslint-disable no-fallthrough */\r\nimport React, { useEffect, useRef } from \"react\";\r\nimport \"./Paper.css\";\r\nimport \"../../../style/main.css\";\r\nimport * as componentsFunction from \"../../../helper/CbmisFunction\";\r\nimport useCheckScreenSize from \"../../../hook/useCheckScreenSize\";\r\nimport { setSxClassName } from \"../../../helper/convertJsCss\";\r\nimport { strTestProps } from \"../../../helper/CbmisVariables\";\r\n\r\nconst Paper = (props) => {\r\n const { elevation, width, outline, sx, hidden, disabled, dir, className, id, ...rest } = props;\r\n const screenWidth = useCheckScreenSize();\r\n\r\n if(props?.[strTestProps]){\r\n if(props?.elevation && props?.width && props?.outline){\r\n console.log(\"Paper\", \"elevation\", \"width\", \"outline\");\r\n }else if(props?.elevation){\r\n console.log(\"Paper\", \"elevation\");\r\n }else if(props?.width){\r\n console.log(\"Paper\", \"width\",);\r\n }else if(props?.outline){\r\n console.log(\"Paper\", \"outline\");\r\n }\r\n if(props?.sx){\r\n console.log(\"Paper\", \"sx\",);\r\n }\r\n }\r\n\r\n const getID = useRef(id || componentsFunction.randomName(\"Paper\"));\r\n const styleRef = useRef({ strSxClassName: \"\" });\r\n\r\n useEffect(() => {}, [elevation, width, outline, hidden, disabled, dir, className, id]);\r\n\r\n useEffect(() => {\r\n if (sx) {\r\n setSxClassName(styleRef, getID.current, sx, \"cbmis-paper\");\r\n }\r\n }, [sx, screenWidth]);\r\n\r\n const getRestProps = () => {\r\n const newRest = componentsFunction.filterPaddingAndMargin(rest);\r\n return { ...newRest };\r\n };\r\n\r\n const getShadow = () => {\r\n switch (parseInt(elevation)) {\r\n case 0:\r\n return \"cbmis-paper-elevation-0\";\r\n case 1:\r\n return \"cbmis-paper-elevation-1\";\r\n case 2:\r\n return \"cbmis-paper-elevation-2\";\r\n case 3:\r\n return \"cbmis-paper-elevation-3\";\r\n case 4:\r\n return \"cbmis-paper-elevation-4\";\r\n case 5:\r\n return \"cbmis-paper-elevation-5\";\r\n case 6:\r\n return \"cbmis-paper-elevation-6\";\r\n case 7:\r\n return \"cbmis-paper-elevation-7\";\r\n case 8:\r\n return \"cbmis-paper-elevation-8\";\r\n case 9:\r\n return \"cbmis-paper-elevation-9\";\r\n default:\r\n return \"cbmis-paper-elevation-2\";\r\n }\r\n };\r\n\r\n const getWidthClass = () => {\r\n switch (width) {\r\n case \"xl\":\r\n return \"cbmis-width-xl\";\r\n case \"lg\":\r\n return \"cbmis-width-lg\";\r\n case \"md\":\r\n return \"cbmis-width-md\";\r\n case \"sm\":\r\n return \"cbmis-width-sm\";\r\n case \"fluid\":\r\n return \"cbmis-width-fluid\";\r\n case \"half\":\r\n return \"cbmis-width-half\";\r\n default:\r\n return \"cbmis-width-fluid\";\r\n }\r\n };\r\n\r\n const getBorderClass = () => {\r\n switch (parseInt(outline)) {\r\n case 1:\r\n return \"cbmis-border-width-1\";\r\n case 2:\r\n return \"cbmis-border-width-2\";\r\n case 3:\r\n return \"cbmis-border-width-3\";\r\n case 4:\r\n return \"cbmis-border-width-4\";\r\n case 5:\r\n return \"cbmis-border-width-5\";\r\n default:\r\n return \"cbmis-border-width-0\";\r\n }\r\n };\r\n\r\n const shadow = useRef(getShadow());\r\n const widthClass = useRef(getWidthClass());\r\n const borderClass = useRef(getBorderClass());\r\n\r\n return (\r\n \r\n
\r\n {props.children}\r\n
\r\n
\r\n );\r\n};\r\n\r\nexport default Paper;\r\n","import \"./style/var.css\";\r\nimport \"./style/main.css\";\r\n\r\nclass AppStyleConfig {\r\n constructor(intStyleSheetSxIndex, objCSSRuleSxIndex) {\r\n this.intStyleSheetSxIndex = intStyleSheetSxIndex;\r\n this.objCSSRuleSxIndex = objCSSRuleSxIndex;\r\n }\r\n}\r\nexport var appStyleConfig = new AppStyleConfig(-1, {});\r\nexport function updateAppConfig({ intStyleSheetSxIndex = undefined, objCSSRuleSxIndex = undefined }) {\r\n if (intStyleSheetSxIndex !== null && intStyleSheetSxIndex !== undefined) {\r\n appStyleConfig.intStyleSheetSxIndex = intStyleSheetSxIndex;\r\n }\r\n if (objCSSRuleSxIndex !== null && objCSSRuleSxIndex !== undefined) {\r\n appStyleConfig.objCSSRuleSxIndex = objCSSRuleSxIndex;\r\n }\r\n}\r\n\r\n//CbmisRouter\r\nexport {\r\n BrowserRouter,\r\n createBrowserRouter,\r\n HashRouter,\r\n Link,\r\n NavLink,\r\n createHashRouter,\r\n AbortedDeferredError,\r\n Await,\r\n MemoryRouter,\r\n Navigate,\r\n NavigationType,\r\n Outlet,\r\n Route,\r\n Router,\r\n RouterProvider,\r\n Routes,\r\n createMemoryRouter,\r\n createPath,\r\n createRoutesFromChildren,\r\n createRoutesFromElements,\r\n defer,\r\n isRouteErrorResponse,\r\n generatePath,\r\n json,\r\n matchPath,\r\n matchRoutes,\r\n parsePath,\r\n redirect,\r\n renderMatches,\r\n resolvePath,\r\n unstable_useBlocker,\r\n useActionData,\r\n useAsyncError,\r\n useAsyncValue,\r\n useHref,\r\n useInRouterContext,\r\n useLoaderData,\r\n useLocation,\r\n useMatch,\r\n useMatches,\r\n useNavigate,\r\n useNavigation,\r\n useNavigationType,\r\n useOutlet,\r\n useOutletContext,\r\n useParams,\r\n useResolvedPath,\r\n useRevalidator,\r\n useRouteError,\r\n useRouteLoaderData,\r\n useRoutes,\r\n useLinkClickHandler,\r\n useSearchParams,\r\n} from \"react-router-dom\";\r\n\r\n/*** system*start ***/\r\n\r\n//SecureRoute\r\nexport * as SecureRoute from \"./system/cbmisRouter/SecureRoute/SecureRoute\";\r\n\r\n//cbmisFunction\r\nexport * as ClientFunction from \"./system/cbmisFunction\";\r\n\r\n//CbmisTest\r\nexport * as ClientTest from \"./system/cbmisTest/CbmisTest\";\r\n\r\n//CbmisData\r\nexport * as ClientData from \"./system/cbmisData/CbmisData\";\r\n\r\n//CbmisDirection\r\nexport * as ClientDirection from \"./system/cbmisDirection/CbmisDirection\";\r\nexport * as setDirectionByLanguage from \"./system/cbmisDirection/CbmisDirection\";\r\n\r\n//ClientNotification\r\nexport * as ClientNotification from \"./system/cbmisNotification/cbmisNotification\";\r\n\r\n//cbmis CbmisInfiniteScroll\r\nexport { default as InfiniteScroll } from \"./system/CbmisInfiniteScroll/CbmisInfiniteScroll\";\r\n\r\n/*** system*end ***/\r\n\r\n/*** hook*start ***/\r\n\r\nexport { default as ThemeProvider } from \"./api/ThemeProvider/ThemeProvider\";\r\n\r\n//CbmisContextApi\r\nexport { default as AppProvider } from \"./api/cbmisContextApi/AppProvider\";\r\n\r\n//useCheckUserLoginKey\r\nexport { default as useCheckUserLoginKey } from \"./hook/useCheckUserLoginKey\";\r\n\r\n//cbmis formapi\r\nexport { default as FormControl } from \"./api/cbmisFormapi/FormControl\";\r\nexport { default as useForm } from \"./api/cbmisFormapi/useForm\";\r\nexport { default as FormField } from \"./api/cbmisFormapi/FormField\";\r\n\r\n/*** hook*end ***/\r\n\r\n/*** sybSystem*start ***/\r\n//PermissionControl\r\nexport { default as PermissionControl } from \"./api/CbmisPermissions/PermissionControl\";\r\n\r\n//ManageCategories\r\nexport { default as ManageCategories } from \"./api/ManageCategories/ManageCategories\";\r\nexport { default as SelectCategory } from \"./api/ManageCategories/SelectCategory\";\r\n\r\n//cbmis camera\r\nexport { default as Camera } from \"./api/cbmisCamera/camera/Camera\";\r\nexport { default as useCamera } from \"./api/cbmisCamera/useCamera.js\";\r\n\r\nexport { default as FileUploader } from \"./api/cbmisUploader/uploadImage/ImageUploader\";\r\n\r\nexport { default as ChatBot } from \"./api/cbmisChat/ChatBot\";\r\n\r\nexport { default as VoiceRecorder } from \"./api/cbmisVoiceRecorder/CbmisVoiceRecorder\";\r\nexport { default as useRecorder } from \"./api/cbmisVoiceRecorder/useRecorder\";\r\n\r\n// export { default as AppStorage } from \"./api/appStorage/AppStorage\";\r\n\r\n/*** subSystem*end ***/\r\n\r\n//#region cbmis dataDisplay\r\nexport { default as Avatar } from \"./material/dataDisplay/Avatar/Avatar\";\r\nexport { default as Badge } from \"./material/dataDisplay/Badge/Badge\";\r\nexport { default as Chip } from \"./material/dataDisplay/Chip/Chip\";\r\nexport { default as Counter } from \"./material/dataDisplay/Counter/Counter\";\r\nexport { default as Modal } from \"./material/dataDisplay/Modal/Modal\";\r\nexport { default as ModalHeader } from \"./material/dataDisplay/Modal/ModalHeader\";\r\nexport { default as ModalBody } from \"./material/dataDisplay/Modal/ModalBody\";\r\nexport { default as ModalFooter } from \"./material/dataDisplay/Modal/ModalFooter\";\r\nexport { default as Tooltip } from \"./material/dataDisplay/Tooltip/Tooltip\";\r\nexport { default as Typography } from \"./material/dataDisplay/Typography/Typography\";\r\nexport { default as Table } from \"./material/dataDisplay/Table/Table\";\r\nexport { default as TableHead } from \"./material/dataDisplay/Table/TableHead\";\r\nexport { default as TableBody } from \"./material/dataDisplay/Table/TableBody\";\r\nexport { default as TableFooter } from \"./material/dataDisplay/Table/TableFooter\";\r\nexport { default as TableRow } from \"./material/dataDisplay/Table/TableRow\";\r\nexport { default as TableCell } from \"./material/dataDisplay/Table/TableCell\";\r\nexport { default as VideoPlayer } from \"./material/dataDisplay/videoPlayer/VideoPlayer\";\r\nexport { default as Charts } from \"./material/dataDisplay/charts/Charts\";\r\nexport { default as RadialProgressBar } from \"./material/dataDisplay/RadialProgressBar/RadialProgressBar\";\r\n//#endregion\r\n\r\n//#region cbmis feedback\r\nexport * as Alert from \"./material/feedback/Alert/Alert\";\r\nexport * as Confirmation from \"./material/feedback/Confirmation/Confirmation\";\r\nexport { default as Note } from \"./material/feedback/Note/Note\";\r\n//#endregion\r\n\r\n//#region cbmisInput\r\nexport { default as Button } from \"./material/inputs/Button/Button\";\r\nexport { default as Checkbox } from \"./material/inputs/CheckboxGroup/CheckboxGroup\";\r\nexport { default as DatePicker } from \"./material/inputs/DatePicker/DatePicker\";\r\nexport { default as ErrorMessage } from \"./material/inputs/ErrorMessage/ErrorMessage\";\r\nexport { default as List } from \"./material/inputs/List/List\";\r\nexport { default as MultipleList } from \"./material/inputs/MultipleList/MultipleList\";\r\nexport { default as RadioButtons } from \"./material/inputs/RadioButtons/RadioButtons\";\r\nexport { default as Text } from \"./material/inputs/Text/Text\";\r\nexport { default as TextArea } from \"./material/inputs/TextArea/TextArea\";\r\nexport { default as Password } from \"./material/inputs/Password/Password\";\r\nexport { default as Number } from \"./material/inputs/Number/Number\";\r\nexport { default as Rating } from \"./material/inputs/Rating/Rating\";\r\nexport { default as RangeSlider } from \"./material/inputs/RangeSlider/RangeSlider\";\r\nexport { default as Switch } from \"./material/inputs/Switch/Switch\";\r\nexport { default as Color } from \"./material/inputs/Color/Color\";\r\n\r\n//#endregion\r\n\r\n//#region cbmis layout\r\nexport { default as Box } from \"./material/layout/Box/Box\";\r\nexport { default as Container } from \"./material/layout/Container/Container\";\r\nexport { default as Line } from \"./material/layout/Line/Line\";\r\nexport { default as Grid } from \"./material/layout/Grid/Grid\";\r\n\r\n//cbmis navigation\r\nexport { default as BottomBar } from \"./material/navigation/BottomBar/BottomBar\";\r\nexport { default as Breadcrumbs } from \"./material/navigation/Breadcrumbs/Breadcrumbs\";\r\nexport { default as Drawer } from \"./material/navigation/Drawer/Drawer\";\r\nexport { default as Menu } from \"./material/navigation/Menu/Menu\";\r\nexport { default as MenuItem } from \"./material/navigation/Menu/MenuItem\";\r\nexport { default as Pagination } from \"./material/navigation/Pagination/Pagination\";\r\nexport { default as SpeedDial } from \"./material/navigation/SpeedDial/SpeedDial\";\r\nexport { default as SpeedDialAction } from \"./material/navigation/SpeedDial/SpeedDialAction\";\r\nexport { default as Stepper } from \"./material/navigation/Stepper/Stepper\";\r\nexport { default as Slideshow } from \"./material/navigation/Slideshow/Slideshow\";\r\nexport { default as Tabs } from \"./material/navigation/Tabs/Tabs\";\r\nexport { default as ParallaxScrolling } from \"./material/navigation/ParallaxScrolling/ParallaxScrolling\";\r\nexport { default as AppBar } from \"./material/navigation/AppBar/AppBar\";\r\nexport { default as GroupBar } from \"./material/navigation/groupBar/GroupBar\";\r\nexport { default as Nav } from \"./material/navigation/nav/Nav\";\r\nexport { default as BtnGoToTop } from \"./material/navigation/btnGoToTop/BtnGoToTop\";\r\n//#endregion\r\n\r\n//#region cbmis surfaces\r\nexport { default as Accordion } from \"./material/surfaces/Accordion/Accordion\";\r\nexport { default as AccordionTab } from \"./material/surfaces/Accordion/AccordionTab\";\r\nexport { default as AccordionSummary } from \"./material/surfaces/Accordion/AccordionSummary\";\r\nexport { default as AccordionDetails } from \"./material/surfaces/Accordion/AccordionDetails\";\r\nexport { default as Card } from \"./material/surfaces/Card/Card\";\r\nexport { default as CardFront } from \"./material/surfaces/Card/CardFront\";\r\nexport { default as CardBack } from \"./material/surfaces/Card/CardBack\";\r\nexport { default as CardImage } from \"./material/surfaces/Card/CardImage\";\r\nexport { default as CardDetails } from \"./material/surfaces/Card/CardDetails\";\r\nexport { default as Glass } from \"./material/surfaces/Glass/Glass\";\r\nexport { default as Loader } from \"./material/surfaces/Loader/Loader\";\r\nexport { default as Paper } from \"./material/surfaces/Paper/Paper\";\r\n//#endregion\r\n\r\nexport { default as Icon } from \"./icon/CbmisIcon\";\r\n\r\n","(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory();\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"@cbmisorg\"] = factory();\n\telse\n\t\troot[\"@cbmisorg\"] = factory();\n})(this, function() {\nreturn ","// The require scope\nvar __webpack_require__ = {};\n\n","// getDefaultExport function for compatibility with non-harmony modules\n__webpack_require__.n = function(module) {\n\tvar getter = module && module.__esModule ?\n\t\tfunction() { return module['default']; } :\n\t\tfunction() { return module; };\n\t__webpack_require__.d(getter, { a: getter });\n\treturn getter;\n};","// define getter functions for harmony exports\n__webpack_require__.d = function(exports, definition) {\n\tfor(var key in definition) {\n\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n\t\t}\n\t}\n};","__webpack_require__.o = function(obj, prop) { return Object.prototype.hasOwnProperty.call(obj, prop); }","// define __esModule on exports\n__webpack_require__.r = function(exports) {\n\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\t}\n\tObject.defineProperty(exports, '__esModule', { value: true });\n};","var __WEBPACK_NAMESPACE_OBJECT__ = require(\"@babel/runtime/helpers/objectWithoutPropertiesLoose\");","var __WEBPACK_NAMESPACE_OBJECT__ = require(\"react\");","//Split variables\r\nexport const Split_Main_Message_Type_Symbol = \"$\"\r\nexport const Split_Message_Symbol = \"~\"\r\nexport const Split_Value_Type_Symbol = \"-\"\r\nexport const Split_Different_Type_Symbol = \"*\"\r\nexport const Split_Same_Message_Type_Symbol = \"/\"\r\n\r\n//#region \r\nexport const Split_validations_Symbol = \"~\"\r\n\r\n//#endregion\r\n\r\n//#region \r\nexport const fieldType = {\r\n text:\"text\",\r\n textArea:\"textarea\",\r\n password:\"password\",\r\n radio:\"radio\",\r\n checkbox:\"checkbox\",\r\n list:\"list\",\r\n multipleList:\"multiplelist\",\r\n date:\"date\",\r\n dateTime:\"datetime\",\r\n number:\"number\",\r\n rangeSlider:\"rangeslider\",\r\n rating:\"rating\",\r\n switch:\"switch\",\r\n color:\"color\",\r\n}\r\n\r\nexport const formValidationsMsg={\r\n required:{eng:\"Required!\",arb:\"الحقل مطلوب\"},\r\n email: {eng:\"The email not valid\",arb:\"البريد اللكتروني غير صحيح\"},\r\n onlynumbers: {eng:\"Only number Required\", arb:\"يجب ان تحتوي القيم فقط أرقام\"},\r\n onlyletters: {eng:\"Only letters Required\", arb:\"يجب ان تحتوي القيم فقط أحرف\"},\r\n maxlength:{eng: \"The digits entered are greater than the allowed limit\", arb: \"عدد الخانات التي تم إدخالها أكبر من الحد المسموح به\"},\r\n minlength:{eng: \"The digits entered are less than the allowed limit\", arb: \"عدد الخانات التي تم إدخالها أقل من الحد المسموح به\"},\r\n maxword:{eng: \"The words entered are greater than the allowed limit\", arb: \"عدد الكلمات التي تم إدخالها أكبر من الحد المسموح به\"},\r\n minword:{eng: \"The words entered are less than the allowed limit\", arb: \"عدد الكلمات التي تم إدخالها أقل من الحد المسموح به\"},\r\n equal:{eng: \"The entered value does not match the required field\", arb: \"القيمة المدخلة غير مطابقة للحقل المطلوب\"},\r\n started: {eng:\"The value entered did not start with the required\", arb:\"لم تبدأ القيمة المدخلة بالمطلوب\"},\r\n ended: {eng:\"The value entered did not end with the required\", arb:\"لم تنتهي القيمة المدخلة بالمطلوب\"},\r\n included: {eng:\"The value you entered did not have the required value\", arb:\"لم تحتوي القيمة المدخلة بالقيمة المطلوبة\"},\r\n password:{\r\n eng:\"The password must be at least 8 characters long including a number, upper and lowercase letters, and one special character\",\r\n arb:\"يجب أن تتكون كلمة المرور من 8 أحرف على الأقل بما في ذلك رقم وأحرف كبيرة وصغيرة وحرف خاص واحد\"}\r\n}\r\n","var __WEBPACK_NAMESPACE_OBJECT__ = require(\"@cbmisorg/material\");","var __WEBPACK_NAMESPACE_OBJECT__ = require(\"react/jsx-runtime\");","import { forwardRef } from \"react\";\r\n\r\nimport * as FormVariables from \"../formHelper/formVariables/FormVariables\";\r\nimport {\r\n Text,\r\n RadioButtons,\r\n List,\r\n CheckboxGroup,\r\n MultipleList,\r\n Password,\r\n TextArea,\r\n DatePicker,\r\n Number,\r\n RangeSlider,\r\n // Rating,\r\n // Color,\r\n Switch,\r\n} from \"@cbmisorg/material\";\r\n\r\nconst fieldsType = FormVariables.fieldType;\r\nconst FormControl = forwardRef((/**@type{any}*/ props, ref) => {\r\n const { handler = {}, defaultValue, children, optionLang, setCurrentLang, funChange, iconColor, iconSize, ...rest } = props;\r\n let value = defaultValue;\r\n if (value?.value) {\r\n value.value = typeof value.value === \"object\" ? JSON?.stringify(value.value) : value.value;\r\n }\r\n value = typeof value === \"object\" ? JSON?.stringify(value) : value;\r\n\r\n const onChangeText = (event) => {\r\n funChange(event, false);\r\n };\r\n const onBlurText = (event) => {\r\n funChange(event, true);\r\n };\r\n switch (String(handler?.control).toLowerCase()) {\r\n case fieldsType.text:\r\n return ;\r\n case fieldsType.textArea:\r\n return (\r\n \r\n );\r\n case fieldsType.password:\r\n return ;\r\n case fieldsType.number:\r\n return ;\r\n case fieldsType.date:\r\n return ;\r\n case fieldsType.dateTime:\r\n return ;\r\n case fieldsType.radio:\r\n return ;\r\n case fieldsType.list:\r\n return
;\r\n case fieldsType.checkbox:\r\n return ;\r\n case fieldsType.multipleList:\r\n return ;\r\n case fieldsType.rangeSlider:\r\n return ;\r\n // case fieldsType.rating:\r\n // return ;\r\n case fieldsType.switch:\r\n return ;\r\n // case fieldsType.color:\r\n // return ;\r\n default:\r\n return null;\r\n }\r\n});\r\n\r\nexport default FormControl;\r\n","var __WEBPACK_NAMESPACE_OBJECT__ = require(\"@babel/runtime/helpers/jsx\");","import React from 'react'\r\nimport { fieldType } from '../formVariables/FormVariables';\r\n\r\nfunction inputHelper(objectHandler) {\r\n //#region\r\n //#region updateValue\r\n\r\n //#region for text and textarea\r\n const handleTextValueChange = (event, blnSetState) => {\r\n const value = event.target.value\r\n objectHandler?.setValue(value, true, blnSetState)\r\n };\r\n\r\n // for text and textarea with languages\r\n const handleTextLangValueChange = (event, blnSetState) => {\r\n const value = event.target.value\r\n var fieldValue = objectHandler?.getValue() || {};\r\n var language = objectHandler?.language?.field || objectHandler?.language?.current || objectHandler?.language?.default;\r\n if(typeof fieldValue === \"string\" && fieldValue){\r\n if(language && typeof fieldValue === \"string\"){\r\n fieldValue = {\r\n [language]:fieldValue,\r\n }\r\n }else if(typeof fieldValue !==\"object\" && !fieldValue){\r\n fieldValue = {}\r\n }\r\n }\r\n fieldValue[language] = value\r\n if(objectHandler?.validations?.email === true || objectHandler?.validations?.email?.condition === true){\r\n fieldValue[language] = String(value)?.toLowerCase()?.trim()\r\n }\r\n if(objectHandler?.validations?.onlynumbers === true || objectHandler?.validations?.onlynumbers?.condition === true){\r\n fieldValue[language] = String(value)?.trim()\r\n }\r\n\r\n \r\n objectHandler?.setValue(fieldValue, true, blnSetState);\r\n \r\n };\r\n\r\n const handleTextChange = (event, blnSetState)=>{\r\n const isMultiLanguage = objectHandler?.blnLanguage || false\r\n if(!isMultiLanguage){\r\n handleTextValueChange(event, blnSetState)\r\n }else{\r\n handleTextLangValueChange(event, blnSetState)\r\n }\r\n }\r\n //#endregion\r\n\r\n //#region number & rangeSlider\r\n const handleNumberChange = (event, blnSetState)=>{\r\n objectHandler?.setValue(parseInt(event?.target?.value), true, blnSetState)\r\n }\r\n //#endregion\r\n\r\n //#region Ratting\r\n const handleRattingChange = (event, blnSetState)=>{\r\n const id = String(event.target.id).split(\"-\")\r\n const value = parseInt(id[0].charAt(id[0].length - 1))\r\n objectHandler?.setValue(value, true, blnSetState)\r\n }\r\n //#endregion\r\n\r\n const handleColorChange = (event, blnSetState)=>{\r\n const value = event.target.value\r\n objectHandler?.setValue(value, true, blnSetState)\r\n\r\n }\r\n\r\n const handleSwitchChange = (event, blnSetState)=>{\r\n // var options = formState?.fields?.[fieldName]?.options\r\n // if(!Array.isArray(options) && typeof options === \"object\"){\r\n // options= Object.keys(options).map(value => {\r\n // return {key: options[value], value: value}\r\n // })\r\n // }\r\n // var item = options?.[0] || { key: false, value: \"off\" }\r\n // if(event.target.checked){\r\n // item = options?.[1] || { key: true, value: \"on\" }\r\n // }\r\n // setValue(fieldName, item, blnSetState)\r\n if(event.target.checked)\r\n objectHandler?.setValue(true, true, blnSetState)\r\n else\r\n objectHandler?.setValue(false, true, blnSetState)\r\n }\r\n //#endregion\r\n\r\n //#region for radio and list\r\n const handleOptionInputChange = (event, blnSetState) => {\r\n const value = event.target.value\r\n var key = event.target.value\r\n if (event.target.id !== \"\") {\r\n key = event.target.id;\r\n }\r\n let item= {\"key\":key,\"value\":value}\r\n objectHandler?.setValue(item,true, blnSetState)\r\n };\r\n //#endregion\r\n\r\n //#region for checkbox and multipleList\r\n const handleMultipleOptionsInputChange = (event, blnSetState) => {\r\n const value = event.target.value\r\n var key = event.target.value\r\n if (event.target.id !== \"\") {\r\n key = event.target.id;\r\n }\r\n\r\n let item= {\"key\":key,\"value\":value}\r\n objectHandler?.setValue(item,true)\r\n\r\n };\r\n //#endregion\r\n\r\n const fieldHandelChange=(event, blnSetState=true)=>{\r\n const control = String(objectHandler?.control).toLowerCase()\r\n if(control === fieldType.number || control === fieldType.rangeSlider){\r\n handleNumberChange(event, blnSetState)\r\n }else if(control === fieldType.radio || control === fieldType.list){\r\n handleOptionInputChange(event, blnSetState)\r\n }else if(control === fieldType.checkbox || control === fieldType.multipleList){\r\n handleMultipleOptionsInputChange(event, blnSetState)\r\n }else if(control === fieldType.rating){\r\n handleRattingChange(event, blnSetState)\r\n }else if(control === fieldType.color){\r\n handleColorChange(event, blnSetState)\r\n }else if(control === fieldType.switch){\r\n handleSwitchChange(event, blnSetState)\r\n }else{\r\n handleTextChange(event, blnSetState)\r\n }\r\n }\r\n\r\n //#endregion\r\n return {\r\n fieldHandelChange\r\n }\r\n}\r\n\r\nexport default inputHelper","import React, { forwardRef, useRef } from 'react'\r\nimport { useMemo } from 'react'\r\nimport FormControl from './FormControl'\r\nimport inputHelper from '../formHelper/formFunctions/inputHelper'\r\n\r\n\r\nconst FormField = forwardRef((/**@type{any}*/props, ref) => {\r\n const {objHandler=null, children, onChange, currentLang=null,...rest} = props\r\n\r\n const {fieldHandelChange} =inputHelper(objHandler)\r\n\r\n const onFieldChange=(event, blnSetState=true)=>{\r\n fieldHandelChange(event, blnSetState);\r\n if(onChange) onChange(event)\r\n }\r\n\r\n const FormCrl = useMemo(() => {\r\n const objLang = objHandler?.language\r\n return(\r\n !objHandler? null:(\r\n \r\n \r\n \r\n )\r\n )\r\n }, [children, objHandler, rest])\r\n\r\n return FormCrl\r\n})\r\n\r\nexport default FormField","import { ClientFunction } from \"@cbmisorg/helper\";\r\n\r\nconst { checkParseObject } = ClientFunction;\r\n//#region update Values\r\n\r\nexport const getOptions = (fieldName, field = {}, objDefLabel = {}, optionList = null) => {\r\n try {\r\n const newObjDefaultLabel = {\r\n ...objDefLabel?.labels?.[fieldName]?.options,\r\n };\r\n if (field?.options || optionList) {\r\n const newOptArr = [];\r\n let lstOptions = optionList ? optionList : field?.options || [];\r\n if (Array.isArray(lstOptions)) {\r\n (lstOptions || [])?.forEach((opt) => {\r\n if (typeof opt === \"object\") {\r\n newOptArr.push({\r\n key: opt?.key,\r\n value: opt?.value || newObjDefaultLabel?.[opt?.value] || newObjDefaultLabel?.[opt?.key],\r\n jsx: opt?.jsx || null,\r\n });\r\n } else {\r\n newOptArr.push({\r\n key: opt,\r\n value: newObjDefaultLabel?.[opt] || opt,\r\n });\r\n }\r\n });\r\n } else if (typeof lstOptions === \"object\") {\r\n Object?.entries(lstOptions || {})?.forEach((opt) => {\r\n newOptArr.push({\r\n key: opt[0],\r\n value: opt[1] || newObjDefaultLabel?.[opt[1]] || newObjDefaultLabel?.[opt[0]],\r\n jsx: opt[2] || null,\r\n });\r\n });\r\n } else if (typeof lstOptions === \"string\" || typeof lstOptions === \"number\" || typeof lstOptions === \"boolean\") {\r\n newOptArr.push({\r\n key: field?.options,\r\n value: newObjDefaultLabel?.[field?.options] || field?.options,\r\n });\r\n }\r\n return newOptArr;\r\n }\r\n return null;\r\n } catch (error) {\r\n return [];\r\n }\r\n};\r\n/**\r\n *\r\n * @param {\"datetime\" | \"date\"} type\r\n */\r\nexport function convertDateToInputForm(date, type) {\r\n try {\r\n if (type === \"datetime\") {\r\n let dtmInput = new Date(date);\r\n dtmInput.setMinutes(dtmInput.getMinutes() - dtmInput.getTimezoneOffset());\r\n let strInputDate = dtmInput.toISOString().slice(0, 16);\r\n return strInputDate;\r\n } else {\r\n let dtmInput = new Date(date);\r\n let strInputDate = dtmInput.toISOString().slice(0, 10);\r\n return strInputDate;\r\n }\r\n } catch {\r\n if (type === \"datetime\") {\r\n let dtmInput = new Date();\r\n dtmInput.setMinutes(dtmInput.getMinutes() - dtmInput.getTimezoneOffset());\r\n let strInputDate = dtmInput.toISOString().slice(0, 16);\r\n return strInputDate;\r\n } else {\r\n let dtmInput = new Date();\r\n let strInputDate = dtmInput.toISOString().slice(0, 10);\r\n return strInputDate;\r\n }\r\n }\r\n}\r\n\r\nexport function updateValue(newValue, fieldName, formState = null, objDefLabel) {\r\n try {\r\n var theNewValue = typeof newValue === \"boolean\" ? newValue : checkParseObject(newValue) || \"\";\r\n\r\n if (formState && formState?.[fieldName]) {\r\n const newFormState = formState || {};\r\n const field = newFormState?.[fieldName];\r\n let lstOptionTmp = getOptions(fieldName, field, objDefLabel) || [];\r\n const strControl = String(field?.control).toLowerCase();\r\n\r\n if (strControl === \"list\" || strControl === \"radio\") {\r\n let objValue = {};\r\n for (let i = 0; i < lstOptionTmp.length; i++) {\r\n if (typeof theNewValue !== \"object\" && String(lstOptionTmp[i]?.key) === String(theNewValue)) {\r\n objValue = lstOptionTmp[i];\r\n break;\r\n } else if (typeof theNewValue === \"object\" && String(lstOptionTmp[i]?.key) === String(theNewValue.key)) {\r\n objValue = lstOptionTmp[i];\r\n break;\r\n }\r\n }\r\n\r\n formState[fieldName].value = objValue;\r\n } else if (strControl === \"checkbox\" || strControl === \"multiplelist\") {\r\n let valueTmp = Array.isArray(theNewValue) ? theNewValue : [];\r\n\r\n let letValue = [];\r\n let keysTmp = valueTmp.map((val) => {\r\n if (typeof val === \"object\") {\r\n return String(val?.key);\r\n }\r\n return String(val);\r\n });\r\n\r\n if (valueTmp?.length) {\r\n for (let i = 0; i < lstOptionTmp.length; i++) {\r\n if (typeof lstOptionTmp[i] !== \"object\" && keysTmp.includes(String(lstOptionTmp[i]))) {\r\n letValue.push(lstOptionTmp[i]);\r\n } else if (typeof lstOptionTmp[i] === \"object\" && keysTmp.includes(String(lstOptionTmp[i]?.key))) {\r\n letValue.push(lstOptionTmp[i]);\r\n }\r\n }\r\n }\r\n\r\n formState[fieldName].value = letValue;\r\n } else if (strControl === \"date\" || strControl === \"datetime\") {\r\n newFormState[fieldName].value = convertDateToInputForm(theNewValue, strControl);\r\n } else if (formState?.[fieldName]?.blnLanguage) {\r\n // var language = formState?.[fieldName]?.language?.field || formState?.[fieldName]?.language?.current || formState?.[fieldName]?.language?.default;\r\n newFormState[fieldName].value = { ...newFormState[fieldName].value, ...theNewValue };\r\n } else {\r\n newFormState[fieldName].value = typeof theNewValue === \"boolean\" ? theNewValue : String(theNewValue)?.trim();\r\n }\r\n return newFormState;\r\n }\r\n return theNewValue;\r\n } catch (error) {\r\n // console.error(error);\r\n }\r\n}\r\n/******************* checkbox add to array Of Values *******************/\r\n\r\nexport function addToCheckboxArray(newPairValue, fieldName, formState = null) {\r\n var currentArrayOfValues = formState?.[fieldName]?.value;\r\n if (!Array.isArray(currentArrayOfValues)) {\r\n currentArrayOfValues = [];\r\n }\r\n if (Array.isArray(newPairValue)) {\r\n currentArrayOfValues = [...currentArrayOfValues, ...newPairValue];\r\n } else if (typeof newPairValue === \"object\") {\r\n currentArrayOfValues = [...currentArrayOfValues, newPairValue];\r\n }\r\n if (formState) {\r\n formState[fieldName].value = currentArrayOfValues;\r\n return { ...formState };\r\n }\r\n return currentArrayOfValues;\r\n}\r\n\r\n/******************* checkbox delete from array Of Values *******************/\r\n\r\nexport function deleteFromCheckboxArray(key, fieldName, formState = null) {\r\n var arrayOfValues = formState?.[fieldName]?.value || [];\r\n var filtered = arrayOfValues?.filter((el) => String(el.key) !== String(key));\r\n if (filtered.length === 0) {\r\n filtered = [];\r\n }\r\n formState[fieldName].value = filtered;\r\n return { ...formState };\r\n}\r\n\r\n//#endregion\r\n\r\n//#region get values formApp\r\nexport function getFormValues(formState) {\r\n const fields = Object.entries(formState);\r\n var valuesObject = {};\r\n fields.map((item) => (valuesObject[item[0]] = item[1]?.value));\r\n return valuesObject;\r\n}\r\n\r\n/******************* get value by fieldName *******************/\r\nexport function getValueByFieldName(field, objDefLabel, blnReset = false) {\r\n try {\r\n if (field && field?.value && !blnReset) {\r\n if (objDefLabel.blnDuplicateLangValue && field.blnLanguage) {\r\n const lstLang = Object.keys(objDefLabel?.objLanguage);\r\n let defaultValue =\r\n field?.value?.[field?.language?.field] ||\r\n field?.value?.[field?.language?.current] ||\r\n field?.value?.[field?.language?.default] ||\r\n field?.value?.[objDefLabel?.currentLang] ||\r\n field?.value?.[objDefLabel?.defaultLang] ||\r\n \"\";\r\n let defaultLangValue = field?.language?.field || field?.language?.current || field?.language?.default || objDefLabel?.currentLang || objDefLabel?.defaultLang;\r\n\r\n let prevDefaultLangValue = field?.prevValue; //String(defaultValue)?.length ? String(defaultValue)?.slice(0, String(defaultValue)?.length - 2) : defaultValue;\r\n if(!field?.language?.field){\r\n field.prevValue = defaultValue\r\n }\r\n \r\n for (let index = 0; index < lstLang.length; index++) {\r\n // console.log(\"#start\", field?.value[lstLang[index]], lstLang[index], defaultValue, defaultLangValue);\r\n if (lstLang[index] === defaultLangValue && field?.value[lstLang[index]]) {\r\n // console.log(\"1\");\r\n defaultValue = field?.value[lstLang[index]];\r\n // field.optionLanguage[lstLang[index]].isLangHaveValue = true;\r\n } else if (lstLang[index] !== defaultLangValue && !field?.language?.field) {\r\n if (\r\n !field?.value?.[lstLang[index]] ||\r\n field?.value?.[lstLang[index]] === prevDefaultLangValue ||\r\n field?.value?.[lstLang[index]] === defaultValue\r\n // || !field.optionLanguage[lstLang[index]].isLangHaveValue\r\n ) {\r\n // console.log(\"2\");\r\n field.value[lstLang[index]] = defaultValue || \"\";\r\n // field.optionLanguage[lstLang[index]].isLangHaveValue = false;\r\n }\r\n // field.optionLanguage[lstLang[index]].isLangHaveValue = true;\r\n }\r\n \r\n // for (let index = 0; index < lstLang.length; index++) {\r\n // if (lstLang[index] === defaultLangValue && field?.value[lstLang[index]]) {\r\n // defaultValue = field?.value[lstLang[index]];\r\n // field.optionLanguage[lstLang[index]].isLangHaveValue = true;\r\n // }else \r\n // if (field?.value?.[lstLang[index]] && !field?.optionLanguage?.[lstLang[index]]?.isLangHaveValue) {\r\n // field.value[lstLang[index]] = defaultValue || \"\"\r\n // field.optionLanguage[lstLang[index]].isLangHaveValue = false;\r\n // }else \r\n // if (field?.value?.[lstLang[index]] && !field?.optionLanguage?.[lstLang[index]]?.isLangHaveValue) {\r\n // field.optionLanguage[lstLang[index]].isLangHaveValue = true;\r\n // }else \r\n // if (!field?.value?.[lstLang[index]]) {\r\n // field.value[lstLang[index]] = defaultValue || \"\"\r\n // field.optionLanguage[lstLang[index]].isLangHaveValue = true;\r\n // }\r\n // }\r\n\r\n // console.log(\"#end\", field?.value[lstLang[index]], lstLang[index], defaultValue, defaultLangValue);\r\n }\r\n }\r\n return field;\r\n } else {\r\n if (String(field?.control).toLocaleLowerCase() === \"checkbox\" || String(field?.control).toLocaleLowerCase() === \"multiplelist\") {\r\n return [];\r\n } else if (String(field?.control).toLocaleLowerCase() === \"switch\") {\r\n return false;\r\n } else if ((String(field?.control).toLocaleLowerCase() === \"text\" || String(field?.control).toLocaleLowerCase() === \"textarea\") && field?.blnLanguage) {\r\n const lstLang = Object.keys(objDefLabel?.objLanguage);\r\n const objValue = {};\r\n lstLang?.forEach((lang) => {\r\n objValue[lang] = \"\";\r\n });\r\n return objValue;\r\n }\r\n return \"\";\r\n }\r\n } catch (error) {\r\n // console.error(error);\r\n if (String(field?.control).toLocaleLowerCase() === \"checkbox\" || String(field?.control).toLocaleLowerCase() === \"multiplelist\") {\r\n return [];\r\n } else if (String(field?.control).toLocaleLowerCase() === \"switch\") {\r\n return false;\r\n } else if ((String(field?.control).toLocaleLowerCase() === \"text\" || String(field?.control).toLocaleLowerCase() === \"textarea\") && field?.blnLanguage) {\r\n const lstLang = Object.keys(objDefLabel?.objLanguage);\r\n const objValue = {};\r\n lstLang?.forEach((lang) => {\r\n objValue[lang] = \"\";\r\n });\r\n return objValue;\r\n }\r\n return \"\";\r\n }\r\n}\r\n\r\n//#endregion\r\n\r\nexport const getDefaultValue = (list, key, value) => {\r\n if (key && value) {\r\n return list.filter((item) => String(item.key) === String(key) && String(item.value) === String(value));\r\n } else if (Array.isArray(key)) {\r\n return list.filter((item) => key.includes(String(item.key)));\r\n } else if (key) {\r\n return list.filter((item) => String(item.key) === String(key));\r\n } else if (value) {\r\n return list.filter((item) => String(item.value) === String(value));\r\n } else {\r\n return \"\";\r\n }\r\n};\r\n","var __WEBPACK_NAMESPACE_OBJECT__ = require(\"@cbmisorg/helper\");","import * as formVariables from \"../formVariables/FormVariables\";\r\n\r\n\r\nexport function getError(name, formState){\r\n try{\r\n return formState?.[name]?.error\r\n }catch(error){\r\n console.error(error);\r\n }\r\n}\r\nexport function updateError(newError, name,formState){\r\n try{\r\n formState[name].error = newError\r\n return {...formState};\r\n }catch(error){\r\n console.error(error);\r\n }\r\n}\r\n\r\nexport const getErrorLabel=(rule,name,formState, objDefLabel)=>{\r\n const theRule= String(rule).toLowerCase()\r\n const fieldValidationsMsg =objDefLabel?.labels?.[name]?.validationsMsg?.[theRule] || objDefLabel?.labels?.[name]?.validationsMsg?.[rule] || null;\r\n const formValidationsMsg = objDefLabel?.defaultValidationsMsg?.[theRule] || objDefLabel?.defaultValidationsMsg?.[rule]\r\n\r\n return fieldValidationsMsg || formValidationsMsg\r\n }","\r\nimport * as valueFunction from \"./ValuesFunctions\";\r\nimport * as errorsFunctions from \"./ErrorsFunctions\";\r\n\r\n//#region check all form values\r\n\r\n export function checkFormValues(formState, objDefLabel){\r\n const fields = Object.entries(formState);\r\n let newFormState = formState\r\n const validationFields = fields.filter(field=>field[1].validations)\r\n validationFields.forEach(field=>{\r\n newFormState = performValidation(field[0],newFormState, objDefLabel)\r\n });\r\n\r\n return {...newFormState}\r\n }\r\n\r\nexport function isFormValid(newFormStates){\r\n const fields = Object.values(newFormStates)\r\n return(fields.every(field => {return field.error === \"\"})) \r\n }\r\n\r\n export function performValidation(fieldName, formState, objDefLabel){\r\n const field = formState?.[fieldName]\r\n if(field?.hidden || field?.disabled){\r\n return formState\r\n }else{\r\n let newFiled= checkFormValueByState(fieldName,formState, objDefLabel)\r\n const newFormState = formState\r\n newFormState[fieldName]= newFiled\r\n return {...newFormState}\r\n }\r\n \r\n }\r\n//#endregion\r\n\r\n\r\n//#region check values\r\n\r\n const langValue = (fieldName,formState, objDefLabel)=>{\r\n const isMultiLanguage = formState?.[fieldName]?.blnLanguage || false\r\n const fieldValue= formState?.[fieldName]?.getValue()\r\n if(isMultiLanguage && (String(formState?.[fieldName]?.control).toLowerCase() === \"text\" || String(formState?.[fieldName]?.control).toLowerCase() === \"textarea\")){\r\n const lstValue=[]\r\n Object.keys(objDefLabel?.objLanguage).forEach(lang=>{\r\n if(!fieldValue?.[lang] && objDefLabel?.objLanguage?.[lang]?.blnIsMandatory){\r\n lstValue.push(\"\")\r\n }else if(fieldValue?.[lang]){\r\n lstValue.push(fieldValue?.[lang])\r\n }\r\n })\r\n return lstValue\r\n }\r\n return fieldValue\r\n }\r\n\r\n\r\n export function checkFormValueByState(fieldName,formState, objDefLabel){\r\n try {\r\n const newFiled = formState?.[fieldName];\r\n newFiled.error= \"\"\r\n const filedValue= langValue(fieldName,formState, objDefLabel)\r\n const emailValid = Email(filedValue)\r\n\r\n const objFunValidation={\r\n required:(validValue)=>Required(filedValue),\r\n email:(validValue)=> emailValid,\r\n onlynumbers:(validValue)=>OnlyNumbers(filedValue),\r\n onlyletters:(validValue)=>OnlyLetters(filedValue),\r\n maxlength:(validValue)=>maxLength(filedValue,validValue),\r\n minlength:(validValue)=>minLength(filedValue,validValue),\r\n maxword:(validValue)=>maxWord(filedValue,validValue),\r\n minword:(validValue)=>minWord(filedValue,validValue),\r\n maxnumber:(validValue)=>maxNumber(filedValue,validValue),\r\n minnumber:(validValue)=>minNumber(filedValue,validValue),\r\n\r\n password:(validValue)=>password(filedValue),\r\n included:(validValue)=>included(filedValue,validValue),\r\n started:(validValue)=>started(filedValue,validValue),\r\n ended:(validValue)=>ended(filedValue,validValue),\r\n\r\n equal:(validValue)=>{\r\n const fieldValue2 = formState?.[validValue]?.getValue() \r\n return equal(filedValue,fieldValue2)\r\n },\r\n\r\n rule:(validValue)=>customRule(validValue)\r\n }\r\n\r\n Object.entries(newFiled?.validations || {}).every(([key,value]) =>{\r\n const rule = key\r\n const ruleLowerCase = String(rule)?.toLowerCase()\r\n let userRule = value;\r\n if (value && typeof value === \"function\") {\r\n userRule = value(filedValue);\r\n }\r\n let blnIsValid = true;\r\n if (objFunValidation?.[ruleLowerCase] && (userRule || userRule === 0)) {\r\n blnIsValid = objFunValidation?.[ruleLowerCase](userRule); \r\n }\r\n\r\n if (value && !blnIsValid) {\r\n newFiled.error = errorsFunctions.getErrorLabel(rule, fieldName, formState, objDefLabel);\r\n return false;\r\n }\r\n\r\n // if(value && objFunValidation?.[ruleLowerCase](value)===false){\r\n // newFiled.error = errorsFunctions.getErrorLabel(rule,fieldName,formState, objDefLabel);\r\n // return false\r\n // }\r\n return blnIsValid\r\n })\r\n return newFiled\r\n } catch (error) {\r\n return formState?.[fieldName]\r\n }\r\n }\r\n\r\n\r\n//#endregion\r\n\r\n/******************* validation Action functions*******************/\r\n//#region\r\n// to check require value\r\nexport function Required(filedValue) {\r\n if(!filedValue){\r\n return false\r\n }else if(Array.isArray(filedValue) && !filedValue?.length){\r\n return false\r\n }\r\n var status = true\r\n if(Array.isArray(filedValue)){\r\n for (let index = 0; index < filedValue.length; index++) {\r\n if(!filedValue[index] || (Array.isArray(filedValue[index]) && !filedValue[index].length)){\r\n status = false\r\n break;\r\n }\r\n }\r\n }\r\n return status \r\n}\r\n\r\nexport function Email(arrEmail) {\r\n const re = /^(([^<>()[\\]\\\\.,;:\\s@\"]+(\\.[^<>()[\\]\\\\.,;:\\s@\"]+)*)|(\".+\"))@((\\[[0-9]{1,3}\\.[0-9]{1,3}\\.[0-9]{1,3}\\.[0-9]{1,3}\\])|(([a-zA-Z\\-0-9]+\\.)+[a-zA-Z]{2,}))$/;\r\n var status = true\r\n\r\n if(Array.isArray(arrEmail) && arrEmail.length > 0){\r\n arrEmail.forEach(email=>{\r\n if(!re.test(String(email).toLowerCase())){\r\n status = false\r\n return status\r\n }\r\n })\r\n }else if(arrEmail !==\"\"){\r\n status = re.test(String(arrEmail).toLowerCase())\r\n }\r\n return status\r\n}\r\n\r\n// to check value is number\r\nexport function OnlyNumbers(arrValue){\r\n const re = /^[0-9,.,٠-٩]+$/;\r\n var status = true\r\n\r\n if(Array.isArray(arrValue) && arrValue.length > 0){\r\n arrValue.forEach(value=>{\r\n if(!re.test(String(value).toLowerCase())){\r\n status = re.test(String(value).toLowerCase())\r\n return re.test(String(value).toLowerCase())\r\n }\r\n })\r\n }else if(arrValue !==\"\"){\r\n status = re.test(String(arrValue).toLowerCase())\r\n }\r\n return status\r\n}\r\n\r\n// to check value is letters\r\nexport function OnlyLetters(arrValue){\r\n const re = /^[A-Za-z\\-\\u0600-\\u06FF, ]+$/;\r\n var status = true\r\n\r\n if(Array.isArray(arrValue) && arrValue.length > 0){\r\n arrValue.forEach(value=>{\r\n if(!re.test(String(value).toLowerCase())){\r\n status = re.test(String(value).toLowerCase())\r\n return re.test(String(value).toLowerCase())\r\n }\r\n })\r\n }else if(arrValue !==\"\"){\r\n status = re.test(String(arrValue).toLowerCase())\r\n }\r\n return status\r\n}\r\n\r\n// to check value1 = value2\r\nexport function equal(value1,value2){ \r\n var status = true \r\n if(Array.isArray(value1) && value1.length > 0){\r\n value1.forEach(value=>{\r\n if(value !== value2){\r\n status = false\r\n return status\r\n }\r\n })\r\n }else if(value1 !==\"\"){\r\n status = value1 === value2 \r\n }\r\n return status\r\n}\r\n\r\n// to check length of the value is less than or equal to maxLength\r\nexport function maxLength(arrValue,length){\r\n var status = true\r\n if(Array.isArray(arrValue) && arrValue.length > 0){\r\n arrValue.forEach(value=>{\r\n if(value.length > parseInt(length)){\r\n status = false\r\n return status\r\n }\r\n })\r\n }else if(arrValue !==\"\"){\r\n status = arrValue.length <= parseInt(length)\r\n }\r\n return status\r\n}\r\n\r\n// to check length of the value is more than or equal to maxLength\r\nexport function minLength(arrValue,length){\r\n var status = true\r\n if(Array.isArray(arrValue) && arrValue.length > 0){\r\n arrValue.forEach(value=>{\r\n if(value.length < parseInt(length)){\r\n status = false\r\n return status\r\n }\r\n })\r\n }else if(arrValue !==\"\"){\r\n status = arrValue.length >= parseInt(length) \r\n }\r\n return status\r\n}\r\n\r\nexport function started(arrValue,strStarted){\r\n var status = true\r\n if(Array.isArray(arrValue) && arrValue.length > 0){\r\n arrValue.forEach(value=>{\r\n if(!String(value).toLowerCase().startsWith(String(strStarted).toLowerCase())){\r\n status = false\r\n return status\r\n }\r\n })\r\n }else if(arrValue !==\"\"){\r\n status = String(arrValue).toLowerCase().startsWith(String(strStarted).toLowerCase())\r\n }\r\n return status\r\n}\r\n\r\nexport function ended(arrValue,strEnded){\r\n var status = true\r\n if(Array.isArray(arrValue) && arrValue.length > 0){\r\n arrValue.forEach(value=>{\r\n if(!String(value).toLowerCase().endsWith(String(strEnded).toLowerCase())){\r\n status = false\r\n return status\r\n }\r\n })\r\n }else if(arrValue !==\"\"){\r\n status = String(arrValue).toLowerCase().endsWith(String(strEnded).toLowerCase())\r\n }\r\n return status\r\n}\r\n\r\nexport function included(arrValue,strIncluded){\r\n var status = true\r\n if(Array.isArray(arrValue) && arrValue.length > 0){\r\n arrValue.forEach(value=>{\r\n if(!String(value).toLowerCase().includes(String(strIncluded).toLowerCase())){\r\n status = false\r\n return status\r\n }\r\n })\r\n }else if(arrValue !==\"\"){\r\n status = String(arrValue).toLowerCase().includes(String(strIncluded).toLowerCase())\r\n }\r\n return status\r\n}\r\n\r\n\r\n// to check length of the value is more than or equal to maxWord\r\nexport function maxWord(arrValue,length){\r\n var status = true\r\n if(Array.isArray(arrValue) && arrValue.length > 0){\r\n arrValue.forEach(value=>{\r\n if(value.split(\" \").length > parseInt(length)){\r\n status = false\r\n return status\r\n }\r\n })\r\n }else if(arrValue !==\"\"){\r\n status = arrValue.split(\" \").length <= parseInt(length)\r\n }\r\n return status\r\n}\r\n\r\n\r\n// to check length of the value is more than or equal to minWord\r\nexport function minWord(arrValue,length){\r\n var status = true\r\n if(Array.isArray(arrValue) && arrValue.length > 0){\r\n arrValue.forEach(value=>{\r\n if(value.split(\" \").length < parseInt(length)){\r\n status = false\r\n return status\r\n }\r\n })\r\n }else if(arrValue !==\"\"){\r\n status = arrValue.split(\" \").length >= parseInt(length)\r\n }\r\n return status\r\n}\r\n\r\n// to check length of the value is more than or equal to maxNumber\r\nexport function maxNumber(arrValue,maxValue){\r\n var status = true\r\n if(Array.isArray(arrValue) && arrValue.length > 0){\r\n arrValue.forEach(value=>{\r\n if(Number(value) > maxValue){\r\n status = false\r\n return status\r\n }\r\n })\r\n }else if(arrValue !==\"\"){\r\n status = Number(arrValue) < maxValue\r\n }\r\n return status\r\n}\r\n\r\n\r\n// to check length of the value is more than or equal to minNumber\r\nexport function minNumber(arrValue,maxValue){\r\n var status = true\r\n if(Array.isArray(arrValue) && arrValue.length > 0){\r\n arrValue.forEach(value=>{\r\n if(Number(value) < maxValue){\r\n status = false\r\n return status\r\n }\r\n })\r\n }else if(arrValue !==\"\"){\r\n status = Number(arrValue) < maxValue\r\n }\r\n return status\r\n}\r\n\r\n// to check passwords according to a specific pattern\r\nexport function password(arrValue){\r\n var status = true\r\n const re = /^(?=.*[0-9])(?=.*[A-Z])(?=.*[a-z])(?=.*[!@#$%^&*])[a-zA-Z0-9!@#$%^&*.]{8,96}$/;\r\n\r\n if(Array.isArray(arrValue) && arrValue.length > 0){\r\n arrValue.forEach(value=>{\r\n if(!re.test(String(value))){\r\n status = re.test(String(value))\r\n return re.test(String(value))\r\n }\r\n })\r\n }else if(arrValue !==\"\"){\r\n status = re.test(String(arrValue))\r\n }\r\n return status\r\n}\r\n\r\nexport function customRule(validValue){\r\n if(typeof validValue ===\"function\"){\r\n return validValue()\r\n }else if(typeof validValue ===\"boolean\"){\r\n return validValue\r\n }else{\r\n return true\r\n }\r\n}\r\n\r\n//#endregion\r\n","import * as ValuesHelper from \"./formFunctions/ValuesFunctions\"\r\nimport * as ValidateHelper from \"./formFunctions/ValidateFunctions\"\r\nimport * as ErrorsHelper from \"./formFunctions/ErrorsFunctions\"\r\n\r\n\r\nexport const {getFormValues,\r\n getValueByFieldName,\r\n updateValue,\r\n addToCheckboxArray,\r\n deleteFromCheckboxArray,\r\n getOptions\r\n } = ValuesHelper\r\n\r\nexport const {getError,updateError} = ErrorsHelper\r\n\r\nexport const {\r\n checkFormValues,\r\n isFormValid,\r\n checkFormValueByState,\r\n performValidation\r\n } = ValidateHelper\r\n","import { useMemo, useRef, useState } from \"react\";\r\nimport * as FormHelper from \"../formHelper/FormHelper\";\r\nimport { formValidationsMsg } from \"../formHelper/formVariables/FormVariables\";\r\n\r\nconst defaultLabels = {\r\n currentLang: \"eng\",\r\n defaultLang: \"eng\",\r\n blnDuplicateLangValue: false,\r\n objLanguage: {\r\n arb: { blnIsActive: true, blnIsMandatory: false, label: \"العربية\" },\r\n eng: { blnIsActive: true, blnIsMandatory: true, label: \"English\" },\r\n },\r\n labels: {\r\n strFullName: {\r\n label: { eng: \"Full Name\", arb: \"اسم\" },\r\n placeholder: { eng: \"Full Name\" },\r\n options: {\r\n opt1: { eng: \"\", arb: \"\" },\r\n opt2: { eng: \"\", arb: \"\" },\r\n },\r\n validationsMsg: {\r\n customName: {},\r\n },\r\n },\r\n },\r\n defaultValidationsMsg: formValidationsMsg,\r\n};\r\nfunction useForm(initialState = {}, objDefLabel = {}) {\r\n const refObjDefLabel = useRef({\r\n ...defaultLabels,\r\n ...objDefLabel,\r\n });\r\n const orderNewFields = useRef([]);\r\n const newFormState = useMemo(() => {\r\n const newFormState = {};\r\n const arrayState = Object.keys(initialState);\r\n for (let index = 0; index < arrayState.length; index++) {\r\n const elementKey = arrayState[index];\r\n\r\n const fieldValue = FormHelper.getValueByFieldName(initialState?.[elementKey], refObjDefLabel?.current);\r\n newFormState[elementKey] = {\r\n name: elementKey,\r\n label: refObjDefLabel?.current?.labels?.[elementKey]?.label || initialState?.[elementKey]?.label || \"\",\r\n placeholder: refObjDefLabel?.current?.labels?.[elementKey]?.placeholder || initialState?.[elementKey]?.placeholder || \"\",\r\n validationsMsg: {\r\n ...refObjDefLabel?.current?.defaultValidationsMsg,\r\n ...refObjDefLabel?.current?.labels?.[elementKey]?.validationsMsg,\r\n },\r\n value: fieldValue && fieldValue?.value ? fieldValue?.value : \"\",\r\n\r\n error: \"\",\r\n hidden: false,\r\n disabled: false,\r\n blnLanguage: false,\r\n language: {\r\n current: refObjDefLabel?.current?.currentLang,\r\n default: refObjDefLabel?.current?.defaultLang,\r\n },\r\n optionLanguage: { ...refObjDefLabel?.current?.objLanguage, ...(fieldValue ? fieldValue.optionLanguage : {}) },\r\n options: FormHelper?.getOptions(elementKey, initialState?.[elementKey], refObjDefLabel?.current), //??\r\n ...initialState?.[elementKey],\r\n\r\n isValid: () => isFormValid(elementKey),\r\n getValue: () => getValueByFieldName(formState?.[elementKey]),\r\n getOptions: () => FormHelper?.getOptions(elementKey, formState?.[elementKey], refObjDefLabel?.current, null),\r\n\r\n setControl : (newControl)=>setControl(elementKey, newControl),\r\n setLanguage: (newLang) => setLanguage(elementKey, newLang),\r\n setOptionLanguage: (newObjLang) => setOptionLanguage(elementKey, newObjLang),\r\n setOptions: (newArrayOpt, blnReplaceAll) => setOptions(elementKey, newArrayOpt, blnReplaceAll),\r\n setOption: (optKey, newOptValue) => setOption(elementKey, optKey, newOptValue),\r\n setLabel: (newLabel) => setLabel(elementKey, newLabel),\r\n setPlaceholder: (newPlaceholder) => setPlaceholder(elementKey, newPlaceholder),\r\n setValue: (newValue = null, blnInFormApi = false, blnSetState = true) => setValueByFieldName(elementKey, newValue, blnInFormApi, blnSetState),\r\n setHidden: (hiddenValue = false) => setHidden(elementKey, hiddenValue),\r\n setDisabled: (disabledValue = false) => setDisabled(elementKey, disabledValue),\r\n setError: (newError = \"\") => setError(elementKey, newError),\r\n setValidation: (validationKey = null, validationValue = { condition: true, msg: {} }, newObjValidation = null) =>\r\n setValidationByFieldName(elementKey, validationKey, validationValue, newObjValidation),\r\n };\r\n }\r\n return newFormState;\r\n }, [initialState, refObjDefLabel.current]); //=> function\r\n\r\n const [formState, setFormState] = useState(newFormState); // =>useEffect\r\n\r\n /************************ values functions ***********************/\r\n //#region\r\n const getCurrentFormValues = () => {\r\n return FormHelper.getFormValues(formState);\r\n };\r\n const getValueByFieldName = (field) => {\r\n const fieldValue = FormHelper.getValueByFieldName(field, refObjDefLabel?.current);\r\n if (fieldValue && fieldValue?.value) {\r\n return fieldValue?.value;\r\n }\r\n return \"\";\r\n };\r\n //checkbox value\r\n const addCheckboxValue = (fieldName, newPairValue) => {\r\n let newFormState = FormHelper.addToCheckboxArray(newPairValue, fieldName, formState);\r\n const errorMessage = FormHelper.checkFormValueByState(fieldName, newFormState, refObjDefLabel.current)?.error;\r\n newFormState = FormHelper.updateError(errorMessage, fieldName, newFormState);\r\n setFormState({ ...newFormState });\r\n };\r\n const deleteCheckboxValue = (fieldName, key) => {\r\n let newFormState = FormHelper.deleteFromCheckboxArray(key, fieldName, formState);\r\n const errorMessage = FormHelper.checkFormValueByState(fieldName, newFormState, refObjDefLabel.current)?.error;\r\n newFormState = FormHelper.updateError(errorMessage, fieldName, newFormState);\r\n setFormState({ ...newFormState });\r\n };\r\n\r\n const setValueByFieldName = (fieldName, newValue, blnInFormApi = false, blnSetState = true) => {\r\n try {\r\n const handler = formState?.[fieldName];\r\n if ((String(handler?.control)?.toLowerCase() !== \"checkbox\" && String(handler?.control)?.toLowerCase() !== \"multiplelist\") || !blnInFormApi) {\r\n const theNewValue = typeof newValue === \"boolean\" ? newValue : JSON.stringify(newValue);\r\n let newFormState = FormHelper.updateValue(theNewValue, fieldName, formState, objDefLabel);\r\n const errorMessage = FormHelper.checkFormValueByState(fieldName, newFormState, refObjDefLabel.current)?.error;\r\n newFormState = FormHelper.updateError(errorMessage, fieldName, newFormState);\r\n if (blnSetState) {\r\n setFormState({ ...newFormState });\r\n }\r\n } else {\r\n const valueIndex = (handler?.value || [])?.findIndex(\r\n (item) => item?.key === newValue?.key || String(item?.key) === String(newValue?.key) || item?.key === newValue || String(item?.key) === String(newValue)\r\n );\r\n if (valueIndex === -1) {\r\n addCheckboxValue(fieldName, newValue);\r\n } else {\r\n deleteCheckboxValue(fieldName, newValue?.key || newValue);\r\n }\r\n }\r\n } catch (error) {\r\n console.error(error);\r\n }\r\n };\r\n //#endregion\r\n\r\n /********************** end values functions *********************/\r\n\r\n /************************ validate functions ***********************/\r\n //#region\r\n const isFormValid = (fieldName = null) => {\r\n if (fieldName) {\r\n return FormHelper.getError(fieldName, formState) ? true : false;\r\n } else {\r\n let newFormState = FormHelper.checkFormValues(formState, refObjDefLabel?.current);\r\n setFormState({ ...newFormState });\r\n return FormHelper.isFormValid(newFormState);\r\n }\r\n };\r\n\r\n const setValidationByFieldName = (fieldName, validationKey, validationValue, newObjValidation) => {\r\n try {\r\n if (fieldName) {\r\n let newFormState = { ...formState };\r\n if (newObjValidation) {\r\n newFormState[fieldName].validations = newObjValidation;\r\n } else if (validationKey) {\r\n newFormState[fieldName].validations[validationKey] = validationValue;\r\n }\r\n const errorMessage = FormHelper.checkFormValueByState(fieldName, newFormState)?.error;\r\n newFormState = FormHelper.updateError(errorMessage, fieldName, newFormState);\r\n setFormState({ ...newFormState });\r\n }\r\n } catch (error) {\r\n console.error(error);\r\n }\r\n };\r\n //#endregion\r\n /********************** end validate functions *********************/\r\n\r\n /************************ set functions ***********************/\r\n //#region\r\n\r\n const setControl = (fieldName, newControl) => {\r\n const newFormState = formState;\r\n newFormState[fieldName].control = newControl;\r\n setFormState({ ...newFormState });\r\n };\r\n \r\n const setHidden = (fieldName, newConation) => {\r\n const newFormState = formState;\r\n newFormState[fieldName].hidden = newConation;\r\n setFormState({ ...newFormState });\r\n };\r\n\r\n const setDisabled = (fieldName, newConation) => {\r\n const newFormState = formState;\r\n newFormState[fieldName].disabled = newConation;\r\n setFormState({ ...newFormState });\r\n };\r\n\r\n const setLabel = (fieldName, label) => {\r\n const newFormState = formState;\r\n newFormState[fieldName].label = label;\r\n setFormState({ ...newFormState });\r\n };\r\n\r\n const setPlaceholder = (fieldName, placeholder) => {\r\n const newFormState = formState;\r\n newFormState[fieldName].placeholder = placeholder;\r\n setFormState({ ...newFormState });\r\n };\r\n const setLanguage = (fieldName, newLang) => {\r\n const newFormState = formState;\r\n newFormState[fieldName].language.field = newLang;\r\n setFormState({ ...newFormState });\r\n };\r\n const setOptionLanguage = (fieldName, newOptionsLang) => {\r\n const newFormState = formState;\r\n // field.language.prevField = field?.language?.field\r\n newFormState[fieldName].objOptionLangLabel = newOptionsLang;\r\n setFormState({ ...newFormState });\r\n };\r\n const setError = (fieldName, newError) => {\r\n const newFormState = formState;\r\n newFormState[fieldName].error = newError;\r\n setFormState({ ...newFormState });\r\n };\r\n //#endregion\r\n /************************ end set functions ***********************/\r\n\r\n //#region options\r\n const setOptions = (fieldName, lstOptions = [], blnReplaceAll = false) => {\r\n const newOptions = FormHelper.getOptions(fieldName, formState?.[fieldName], refObjDefLabel?.current, lstOptions);\r\n\r\n if (fieldName && formState?.[fieldName] && JSON.stringify(formState[fieldName].getOptions()) !== JSON.stringify(newOptions)) {\r\n if (blnReplaceAll) {\r\n formState[fieldName].options = newOptions;\r\n } else {\r\n formState[fieldName].options = [...(formState[fieldName].getOptions() || []), ...newOptions];\r\n setFormState({ ...formState });\r\n }\r\n }\r\n };\r\n const setOption = (fieldName, newOptKey, newOptValue) => {\r\n const arrOptions = formState?.[fieldName]?.options || [];\r\n const indexOptions = arrOptions.findIndex((item) => item.key === newOptKey);\r\n const newOptions = arrOptions;\r\n if (indexOptions > -1) {\r\n newOptions[indexOptions] = { key: newOptKey, value: newOptValue };\r\n } else {\r\n newOptions.push({ key: newOptKey, value: newOptValue });\r\n }\r\n formState[fieldName].options = newOptions;\r\n setFormState({ ...formState });\r\n };\r\n\r\n //#endregion\r\n\r\n const resetForm = () => {\r\n Object.keys(formState).forEach((filed) => {\r\n formState[filed].value = FormHelper?.getValueByFieldName(filed, objDefLabel, true);\r\n formState[filed].error = \"\";\r\n formState[filed].language = {\r\n current: refObjDefLabel?.current?.currentLang,\r\n default: refObjDefLabel?.current?.defaultLang,\r\n };\r\n });\r\n setFormState(formState);\r\n };\r\n\r\n //#region Add List Fields\r\n const addListFields = (fields = {}, blnReplaceAll = false) => {\r\n const newFormState = blnReplaceAll ? {} : formState;\r\n if (typeof fields === \"object\") {\r\n Object?.entries(fields || {}).forEach((field) => {\r\n const [fieldName, theField] = field;\r\n\r\n // order\r\n\r\n const fieldValue = FormHelper.getValueByFieldName(theField, refObjDefLabel?.current);\r\n newFormState[fieldName] = {\r\n name: fieldName,\r\n label: refObjDefLabel?.current?.labels?.[fieldName]?.label || theField?.label || \"\",\r\n placeholder: refObjDefLabel?.current?.labels?.[fieldName]?.placeholder || theField?.placeholder || \"\",\r\n validationsMsg: {\r\n ...refObjDefLabel?.current?.defaultValidationsMsg,\r\n ...refObjDefLabel?.current?.labels?.[fieldName]?.validationsMsg,\r\n },\r\n value: fieldValue && fieldValue?.value ? fieldValue?.value : \"\",\r\n\r\n error: \"\",\r\n hidden: false,\r\n disabled: false,\r\n blnLanguage: false,\r\n language: {\r\n current: refObjDefLabel?.current?.currentLang,\r\n default: refObjDefLabel?.current?.defaultLang,\r\n },\r\n optionLanguage: { ...refObjDefLabel?.current?.objLanguage, ...(fieldValue.optionLanguage ? fieldValue.optionLanguage : {}) },\r\n options: FormHelper?.getOptions(fieldName, theField, refObjDefLabel?.current), //??\r\n ...theField,\r\n\r\n isValid: () => isFormValid(fieldName),\r\n getValue: () => getValueByFieldName(formState?.[fieldName]),\r\n getOptions: () => FormHelper?.getOptions(fieldName, formState?.[fieldName], refObjDefLabel?.current, null),\r\n\r\n setLanguage: (newLang) => setLanguage(fieldName, newLang),\r\n setOptionLanguage: (newObjLang) => setOptionLanguage(fieldName, newObjLang),\r\n setOptions: (newArrayOpt, blnReplaceAll) => setOptions(fieldName, newArrayOpt, blnReplaceAll),\r\n setOption: (optKey, newOptValue) => setOption(fieldName, optKey, newOptValue),\r\n setLabel: (newLabel) => setLabel(fieldName, newLabel),\r\n setPlaceholder: (newPlaceholder) => setPlaceholder(fieldName, newPlaceholder),\r\n setValue: (newValue = null, blnInFormApi = false, blnSetState = true) => setValueByFieldName(fieldName, newValue, blnInFormApi, blnSetState),\r\n setHidden: (hiddenValue = false) => setHidden(fieldName, hiddenValue),\r\n setDisabled: (disabledValue = false) => setDisabled(fieldName, disabledValue),\r\n setError: (newError = \"\") => setError(fieldName, newError),\r\n setValidation: (validationKey = null, validationValue = { condition: true, msg: {} }, newObjValidation = null) =>\r\n setValidationByFieldName(fieldName, validationKey, validationValue, newObjValidation),\r\n };\r\n });\r\n\r\n setFormState(newFormState);\r\n }\r\n };\r\n\r\n const deleteListFields = (fields = []) => {\r\n fields.forEach((theField) => {\r\n delete formState?.[theField];\r\n });\r\n setFormState({ ...formState });\r\n };\r\n\r\n const deleteForm = () => {\r\n setFormState({});\r\n };\r\n const setFormLanguage = (newLang) => {\r\n refObjDefLabel.current.currentLang = newLang;\r\n const arrFiled = Object.keys(formState);\r\n for (let index = 0; index < arrFiled.length; index++) {\r\n const element = arrFiled[index];\r\n formState[element].language.current = newLang;\r\n if (formState[element].language.field) {\r\n formState[element].language.field = newLang;\r\n }\r\n }\r\n setFormState({ ...formState });\r\n };\r\n const getFormLanguage = () => {\r\n return {\r\n current: refObjDefLabel.current.currentLang,\r\n default: refObjDefLabel.current.defaultLang,\r\n };\r\n };\r\n return {\r\n ...formState,\r\n controller: {\r\n step: 0,\r\n isFormValid,\r\n getValues: getCurrentFormValues,\r\n addListFields, //[]\r\n deleteListFields,\r\n deleteForm,\r\n getFormLanguage,\r\n setFormLanguage,\r\n resetForm,\r\n orderNewFields: [\"\", \"\"],\r\n },\r\n };\r\n}\r\n\r\nexport default useForm;\r\n","\"use client\";\r\nexport { default as FormControl } from \"./components/FormControl\";\r\nexport { default as FormField } from \"./components/FormField\";\r\nexport { default as useForm } from \"./hooks/useForm\";\r\n","var __WEBPACK_NAMESPACE_OBJECT__ = require(\"crypto-js\");","var __WEBPACK_NAMESPACE_OBJECT__ = require(\"ua-parser-js\");","var __WEBPACK_NAMESPACE_OBJECT__ = require(\"lz-string\");","import * as CryptoJS from \"crypto-js\";\r\nimport { UAParser } from \"ua-parser-js\";\r\nimport lzString from \"lz-string\";\r\n\r\n//#region date functions\r\nexport function blnIsTodayBiggerThanTheDate(theDate) {\r\n const _currentDate = new Date();\r\n const _theDate = new Date(theDate);\r\n return _theDate < _currentDate;\r\n}\r\n\r\nexport const isDate = (theDate) => {\r\n const isDate = Object.prototype.toString.call(theDate) === \"[object Date]\";\r\n const isValidDate = theDate && !Number.isNaN(theDate.valueOf());\r\n return isDate && isValidDate;\r\n};\r\n\r\nexport function getCurrentDate(date = null) {\r\n if (date !== null) {\r\n return new Date(date);\r\n } else {\r\n return new Date();\r\n }\r\n}\r\n\r\nexport function addDaysToDate(date = null, days) {\r\n let dtm = new Date();\r\n try {\r\n if (date) {\r\n dtm = new Date(date);\r\n }\r\n } catch {\r\n dtm = new Date();\r\n }\r\n const newDate = new Date();\r\n newDate.setDate(dtm.getDate() + Number(days));\r\n\r\n return newDate;\r\n}\r\n\r\nexport function getDateUSFormat(dtmDate, fullDate = false) {\r\n try {\r\n if (fullDate) {\r\n return new Date(dtmDate).toLocaleString(\"default\", {\r\n month: \"short\",\r\n day: \"numeric\",\r\n year: \"2-digit\",\r\n hour: \"numeric\",\r\n minute: \"2-digit\",\r\n second: \"numeric\",\r\n hour12: false,\r\n });\r\n }\r\n return new Date(dtmDate).toLocaleDateString(\"default\", { month: \"short\", day: \"numeric\", year: \"2-digit\" });\r\n } catch {\r\n if (fullDate) {\r\n return new Date(dtmDate).toLocaleString(\"default\", { month: \"short\", day: \"numeric\", year: \"2-digit\" });\r\n }\r\n return new Date(dtmDate).toLocaleDateString(\"default\", { month: \"short\", day: \"numeric\", year: \"2-digit\" });\r\n }\r\n}\r\n\r\nexport function getISODate(theDate, time_OR_date_OR_all = \"all\") {\r\n switch (time_OR_date_OR_all) {\r\n case \"time\":\r\n const time = new Date(theDate).toISOString().split(\"T\")[1];\r\n return time.slice(1, time.length - 5);\r\n case \"date\":\r\n return new Date(theDate).toISOString().split(\"T\")[0];\r\n case \"all\":\r\n return new Date(theDate).toISOString();\r\n default:\r\n return null;\r\n }\r\n}\r\n\r\n/**\r\n * - Its will get future date of previous date as object of Date.\r\n * @param {Date} [currentDate] by default now date\r\n * @param {number} intEditFactor may represent number of year or month or day or hour or minute or second.\r\n * @param {\"second\" | \"minute\" | \"hour\" | \"day\" | \"month\" | \"year\"} strJumpPeriodType represent number of (intEditFactor) you want to pass.\r\n * @param {\"after\" | \"before\" } strMomentType to get date in future or past\r\n * @returns {Date}\r\n */\r\nexport function getSpecificDateFromNow(strMomentType, strJumpPeriodType, intEditFactor, currentDate = new Date()) {\r\n try {\r\n let currentDateFromUnixEpoch = new Date(currentDate).getTime();\r\n switch (strMomentType) {\r\n case \"after\":\r\n switch (strJumpPeriodType) {\r\n case \"second\":\r\n return new Date(currentDateFromUnixEpoch + intEditFactor * 1000);\r\n case \"minute\":\r\n return new Date(currentDateFromUnixEpoch + intEditFactor * 1000 * 60);\r\n case \"hour\":\r\n return new Date(currentDateFromUnixEpoch + intEditFactor * 1000 * 60 * 60);\r\n case \"day\":\r\n return new Date(currentDateFromUnixEpoch + intEditFactor * 1000 * 60 * 60 * 24);\r\n case \"month\":\r\n return new Date(currentDateFromUnixEpoch + intEditFactor * 1000 * 60 * 60 * 24 * 30.4375);\r\n case \"year\":\r\n return new Date(currentDateFromUnixEpoch + intEditFactor * 1000 * 60 * 60 * 24 * 30.4375 * 12);\r\n default:\r\n return new Date();\r\n }\r\n case \"before\":\r\n switch (strJumpPeriodType) {\r\n case \"second\":\r\n return new Date(currentDateFromUnixEpoch - intEditFactor * 1000);\r\n case \"minute\":\r\n return new Date(currentDateFromUnixEpoch - intEditFactor * 1000 * 60);\r\n case \"hour\":\r\n return new Date(currentDateFromUnixEpoch - intEditFactor * 1000 * 60 * 60);\r\n case \"day\":\r\n return new Date(currentDateFromUnixEpoch - intEditFactor * 1000 * 60 * 60 * 24);\r\n case \"month\":\r\n return new Date(currentDateFromUnixEpoch - intEditFactor * 1000 * 60 * 60 * 24 * 30.4375);\r\n case \"year\":\r\n return new Date(currentDateFromUnixEpoch - intEditFactor * 1000 * 60 * 60 * 24 * 30.4375 * 12);\r\n default:\r\n return new Date();\r\n }\r\n default:\r\n return new Date();\r\n }\r\n } catch {\r\n return new Date();\r\n }\r\n}\r\n\r\n/**\r\n * - This function return different between dtmOldestDate and dtmNewestDate, strIntervalReturnValue specify period of deference.\r\n * - If error occurs NaN will return.\r\n * - dtmOldestDate > dtmNewestDate => less than 0\r\n * - dtmOldestDate < dtmNewestDate => great than 0\r\n * @param {Date | string} dtmOldestDate\r\n * @param {Date | string} dtmNewestDate\r\n * @param {\"second\" | \"minute\" | \"hour\" | \"day\" | \"month\" | \"year\"} strIntervalReturnValue\r\n * @returns {number}\r\n */\r\n\r\nexport function getDifferenceBetweenTwoDate(dtmOldestDate, dtmNewestDate, strIntervalReturnValue) {\r\n try {\r\n const intTime2 = new Date(dtmNewestDate).getTime();\r\n const intTime1 = new Date(dtmOldestDate).getTime();\r\n const diffTime = intTime2 - intTime1;\r\n\r\n switch (strIntervalReturnValue) {\r\n case \"second\":\r\n return diffTime / 1000;\r\n case \"minute\":\r\n return diffTime / 1000 / 60;\r\n case \"hour\":\r\n return diffTime / 1000 / 60 / 60;\r\n case \"day\":\r\n return diffTime / 1000 / 60 / 60 / 24;\r\n case \"month\":\r\n return diffTime / 1000 / 60 / 60 / 24 / 30.4375;\r\n case \"year\":\r\n return diffTime / 1000 / 60 / 60 / 24 / 30.4375 / 12;\r\n default:\r\n return Number.NaN;\r\n }\r\n } catch (error) {\r\n return Number.NaN;\r\n }\r\n}\r\n\r\n/**\r\n * @returns {boolean}\r\n */\r\nexport function checkIsValidDate(date) {\r\n if (!date || String(date).length < 1) {\r\n return false;\r\n }\r\n\r\n let dtmTmpDate = null;\r\n\r\n try {\r\n dtmTmpDate = new Date(date);\r\n } catch {}\r\n\r\n if (!dtmTmpDate || typeof dtmTmpDate?.getMonth !== \"function\" || Object.prototype.toString.call(dtmTmpDate) !== \"[object Date]\" || !(dtmTmpDate instanceof Date) || isNaN(dtmTmpDate)) {\r\n return false;\r\n }\r\n\r\n return true;\r\n}\r\n\r\nexport function excelDateToJSDate(serial) {\r\n var utc_days = Math.floor(serial - 25569);\r\n var utc_value = utc_days * 86400;\r\n var date_info = new Date(utc_value * 1000);\r\n\r\n var fractional_day = serial - Math.floor(serial) + 0.0000001;\r\n\r\n var total_seconds = Math.floor(86400 * fractional_day);\r\n\r\n var seconds = total_seconds % 60;\r\n\r\n total_seconds -= seconds;\r\n\r\n var hours = Math.floor(total_seconds / (60 * 60));\r\n var minutes = Math.floor(total_seconds / 60) % 60;\r\n\r\n return new Date(date_info.getFullYear(), date_info.getMonth(), date_info.getDate(), hours, minutes, seconds);\r\n}\r\n\r\n//#endregion\r\n\r\n/////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////\r\n\r\n//#region checking fun\r\n\r\nexport function checkParseObject(object) {\r\n try {\r\n if (object === undefined || object === null) {\r\n throw new Error(\"Unsupported data-type\");\r\n }\r\n if (typeof object === \"string\") {\r\n return JSON.parse(object);\r\n } else if (typeof object === \"object\") {\r\n return object;\r\n } else {\r\n throw new Error(\"Unsupported data-type\");\r\n }\r\n } catch (error) {\r\n return {};\r\n }\r\n}\r\n\r\nexport function checkIsObjectFine(object) {\r\n try {\r\n if (\r\n object !== undefined &&\r\n object !== null &&\r\n object &&\r\n String(object).length > 2 &&\r\n String(object) !== \"undefined\" &&\r\n String(object) !== \"null\" &&\r\n String(object) !== \"\" &&\r\n String(object) !== \" \"\r\n ) {\r\n return true;\r\n }\r\n return false;\r\n } catch {\r\n return false;\r\n }\r\n}\r\n\r\nexport function checkNumber(number) {\r\n if (isNaN(Number(number))) {\r\n return 0;\r\n } else {\r\n return Number(number);\r\n }\r\n}\r\n\r\nexport function safeInvoke(theObject, strKeyNameTarget) {\r\n try {\r\n return theObject[strKeyNameTarget];\r\n } catch (error) {\r\n return null;\r\n }\r\n}\r\n\r\nexport const trimDash = (value) => {\r\n const strValue = String(value);\r\n if (strValue.includes(\"-\")) {\r\n let temp = \"\";\r\n for (let i = 0; i < strValue.length; i++) {\r\n if (strValue.charAt(i) !== \"-\") {\r\n temp = temp + strValue.charAt(i);\r\n }\r\n }\r\n return temp;\r\n }\r\n return value;\r\n};\r\n\r\nexport function checkFileName(objFile, strAlternativeName) {\r\n let fileName = String(objFile.name);\r\n const isContainNoneLatinsChar = /[^\\u0020-\\u007E]/.test(fileName);\r\n if (isContainNoneLatinsChar === true) {\r\n let lstSplitString = fileName.split(\".\");\r\n let strFileExtension = lstSplitString[lstSplitString.length - 1];\r\n let newFileName = strAlternativeName + \".\" + strFileExtension;\r\n return new File([objFile], newFileName, objFile);\r\n } else {\r\n return objFile;\r\n }\r\n}\r\n\r\nexport const compareTwoArraysIsEqual = (array1, array2) => {\r\n if (Array.isArray(array1) && Array.isArray(array2) && array1.length === array2.length) {\r\n array1.sort();\r\n array2.sort();\r\n let blnIsEqual = true;\r\n for (var i = 0; i < array1.length; i++) {\r\n if (JSON.stringify(array1[i]) !== JSON.stringify(array2[i])) {\r\n blnIsEqual = false;\r\n break;\r\n }\r\n }\r\n return blnIsEqual;\r\n } else {\r\n return false;\r\n }\r\n};\r\n//#endregion\r\n\r\n/////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////\r\n\r\n//#region generating functions\r\n\r\n/**\r\n * Returns a random number\r\n * @param {number} intLength\r\n * @returns {number}\r\n */\r\nexport function getRandomNumber(intLength) {\r\n let intMaxNumber = \"1\";\r\n let intLowerNumber = \"1\";\r\n\r\n for (let i = 0; i < intLength; i++) {\r\n if (i > 0) {\r\n intLowerNumber += \"0\";\r\n }\r\n intMaxNumber += \"0\";\r\n }\r\n\r\n return Math.ceil(Math.random() * (Number(intMaxNumber) - (Number(intLowerNumber) + 1)) + Number(intLowerNumber));\r\n}\r\n\r\n/**\r\n * can generate number up to 64 Digits, > 16 string else number\r\n * @param {number} intGeneratedIDLength\r\n * @returns {string | number}\r\n */\r\nexport function generateID(intGeneratedIDLength = 10) {\r\n //#region make random number series\r\n let dtmCurrentDate = getCurrentDate();\r\n let intCurrentDateFromUnixEpoch = dtmCurrentDate.getTime();\r\n let strCurrentDateFromUnixEpoch = String(intCurrentDateFromUnixEpoch);\r\n\r\n let strRandomNumberPh1 = strCurrentDateFromUnixEpoch;\r\n\r\n if (intGeneratedIDLength > 48) {\r\n strRandomNumberPh1 = strCurrentDateFromUnixEpoch + String(getRandomNumber(16)) + String(getRandomNumber(16)) + String(getRandomNumber(16)) + String(getRandomNumber(16));\r\n } else if (intGeneratedIDLength > 32) {\r\n strRandomNumberPh1 = strCurrentDateFromUnixEpoch + String(getRandomNumber(16)) + String(getRandomNumber(16)) + String(getRandomNumber(16));\r\n } else if (intGeneratedIDLength > 18) {\r\n strRandomNumberPh1 = strCurrentDateFromUnixEpoch + String(getRandomNumber(16)) + String(getRandomNumber(16));\r\n } else if (intGeneratedIDLength > 6) {\r\n strRandomNumberPh1 = strCurrentDateFromUnixEpoch + String(getRandomNumber(16));\r\n }\r\n //#endregion\r\n\r\n //#region shuffle random numbers\r\n let lstRandomNumberPh2 = Array.from(strRandomNumberPh1);\r\n for (let i = 0; i < lstRandomNumberPh2.length; i++) {\r\n for (let j = 0; j < 2; j++) {\r\n let intRandomIndexFrom = Math.floor(Math.random() * (lstRandomNumberPh2.length - 1 + 1) + 1) - 1;\r\n let intRandomIndexTo = Math.floor(Math.random() * (lstRandomNumberPh2.length - 1 + 1) + 1) - 1;\r\n let strCurrentDigit = lstRandomNumberPh2[intRandomIndexFrom];\r\n lstRandomNumberPh2[intRandomIndexFrom] = lstRandomNumberPh2[intRandomIndexTo];\r\n lstRandomNumberPh2[intRandomIndexTo] = strCurrentDigit;\r\n }\r\n }\r\n //#endregion\r\n\r\n //#region minimizing zeros\r\n let strRandomNumberPh3 = lstRandomNumberPh2.join(\"\");\r\n\r\n let strRandomNumberPh4 = \"\";\r\n let intCounter = 0;\r\n let intGroupBy = 13;\r\n for (let i = 0; i < strRandomNumberPh3.length; i++) {\r\n if (i * intGroupBy >= strRandomNumberPh3.length - 1) {\r\n let intNumberTmp = Number(strRandomNumberPh3.substring(intCounter * intGroupBy, strRandomNumberPh3.length));\r\n strRandomNumberPh4 += String(intNumberTmp);\r\n break;\r\n } else {\r\n let intNumberTmp = Number(strRandomNumberPh3.substring(intCounter * intGroupBy, (intCounter + 1) * intGroupBy));\r\n strRandomNumberPh4 += String(intNumberTmp);\r\n }\r\n intCounter++;\r\n }\r\n //#endregion\r\n\r\n if (String(strRandomNumberPh4).length > intGeneratedIDLength) {\r\n strRandomNumberPh4 = String(strRandomNumberPh4).slice(0, intGeneratedIDLength);\r\n }\r\n\r\n if (intGeneratedIDLength > 16) {\r\n return String(strRandomNumberPh4);\r\n } else {\r\n return Number(strRandomNumberPh4);\r\n }\r\n}\r\n\r\n//#endregion\r\n\r\n/////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////\r\n\r\n//#region encrypting functions\r\n/**\r\n * To encrypt text by key (strKeyOfEncrypt)\r\n * @param {string} strPlaintText\r\n * @param {string} strKeyOfEncrypt\r\n * @returns {string}\r\n */\r\nexport function encryptText(strPlaintText = \"\", strKeyOfEncrypt = \"\") {\r\n // Encrypt\r\n try {\r\n let cipherText = String(CryptoJS.AES.encrypt(strPlaintText, strKeyOfEncrypt));\r\n return cipherText;\r\n } catch (error) {\r\n return null;\r\n }\r\n}\r\n\r\n/**\r\n * To decrypt text by key (strKeyOfDecrypt)\r\n * @param {string} strCipherText\r\n * @param {string} strKeyOfDecrypt\r\n * @returns {string}\r\n */\r\nexport function decryptText(strCipherText, strKeyOfDecrypt) {\r\n //Decrypt\r\n try {\r\n let bytes = CryptoJS.AES.decrypt(strCipherText, strKeyOfDecrypt);\r\n let plaintText = bytes.toString(CryptoJS.enc.Utf8);\r\n return plaintText;\r\n } catch (error) {\r\n return null;\r\n }\r\n}\r\n//#endregion\r\n\r\n/////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////\r\n\r\n//#region storage functions\r\n\r\nexport function recursionResetObject(objAppState) {\r\n let _objAppState = objAppState;\r\n if (typeof _objAppState !== \"object\" || !_objAppState) {\r\n return _objAppState;\r\n }\r\n Object.entries(_objAppState).forEach(([key, value]) => {\r\n if (Array.isArray(value)) {\r\n _objAppState[key] = [];\r\n } else if (typeof value === \"string\") {\r\n _objAppState[key] = \"\";\r\n } else if (typeof value === \"number\" || typeof value === \"bigint\") {\r\n _objAppState[key] = 0;\r\n } else if (typeof value === \"boolean\") {\r\n _objAppState[key] = null;\r\n } else if (typeof value === \"object\" && value instanceof Object && !Array.isArray(value)) {\r\n recursionResetObject(value);\r\n } else {\r\n _objAppState[key] = null;\r\n }\r\n });\r\n\r\n return _objAppState;\r\n}\r\n\r\nexport function setAppLocalStorage(appStateObject, strLocalStorageName, blnIsEncrypted = false, strEncryptKey = \"secret\") {\r\n let plainTextLocalStorage = JSON.stringify(appStateObject);\r\n\r\n if (blnIsEncrypted) {\r\n let cipherTextLocalStorage = encryptText(plainTextLocalStorage, strEncryptKey);\r\n localStorage.setItem(strLocalStorageName, cipherTextLocalStorage);\r\n } else {\r\n localStorage.setItem(strLocalStorageName, plainTextLocalStorage);\r\n }\r\n}\r\n\r\nexport function getAppLocalStorage(strLocalStorageName, blnIsEncrypted = false, strEncryptKey = \"secret\") {\r\n try {\r\n let txtLocalStorage = localStorage.getItem(strLocalStorageName);\r\n\r\n if (blnIsEncrypted) {\r\n let plainTextLocalStorage = decryptText(txtLocalStorage, strEncryptKey);\r\n return checkParseObject(plainTextLocalStorage);\r\n } else {\r\n return checkParseObject(txtLocalStorage);\r\n }\r\n } catch (e) {\r\n return {};\r\n }\r\n}\r\n\r\nexport function clearLocalStorageObject(appStateObject, strLocalStorageName, blnIsEncrypted = false, strEncryptKey = \"secret\", setPayload) {\r\n localStorage.removeItem(strLocalStorageName);\r\n let _appStateObject = appStateObject;\r\n\r\n let clientInfo = null;\r\n if (_appStateObject?.clientInfo) {\r\n clientInfo = checkParseObject(JSON.stringify(_appStateObject.clientInfo));\r\n clientInfo.blnIsUserLoggedIn = false;\r\n clientInfo.dtmLastUpdate = getCurrentDate();\r\n clientInfo.dtmLastRequest = getCurrentDate();\r\n }\r\n\r\n let plainObjLocalStorage = recursionResetObject(_appStateObject);\r\n plainObjLocalStorage = { ...plainObjLocalStorage, clientInfo: clientInfo };\r\n\r\n if (setPayload && typeof setPayload === \"function\") {\r\n setPayload(plainObjLocalStorage);\r\n }\r\n\r\n let plainTextLocalStorage = JSON.stringify(plainObjLocalStorage);\r\n\r\n if (blnIsEncrypted) {\r\n let cipherTextLocalStorage = encryptText(plainTextLocalStorage, strEncryptKey);\r\n localStorage.setItem(strLocalStorageName, cipherTextLocalStorage);\r\n } else {\r\n localStorage.setItem(strLocalStorageName, plainTextLocalStorage);\r\n }\r\n}\r\n\r\nexport function setAppSessionStorage(object, strSessionStorageName, blnIsEncrypted = false, strEncryptKey = \"secret\") {\r\n let plainTextSessionStorage = JSON.stringify(object);\r\n\r\n if (blnIsEncrypted) {\r\n let cipherTextSessionStorage = encryptText(plainTextSessionStorage, strEncryptKey);\r\n sessionStorage.setItem(strSessionStorageName, cipherTextSessionStorage);\r\n } else {\r\n sessionStorage.setItem(strSessionStorageName, plainTextSessionStorage);\r\n }\r\n}\r\n\r\nexport function getAppSessionStorage(strSessionStorageName, blnIsEncrypted = false, strEncryptKey = \"secret\") {\r\n try {\r\n let txtSessionStorage = sessionStorage.getItem(strSessionStorageName);\r\n\r\n if (blnIsEncrypted) {\r\n let plainTextSessionStorage = decryptText(txtSessionStorage, strEncryptKey);\r\n return checkParseObject(plainTextSessionStorage);\r\n } else {\r\n return checkParseObject(txtSessionStorage);\r\n }\r\n } catch (e) {\r\n return {};\r\n }\r\n}\r\n\r\nexport function clearSessionStorageObject(object, SessionStorageName, SessionStorageIsEncrypted = false, SessionStorageKey = \"secret\") {\r\n sessionStorage.removeItem(SessionStorageName);\r\n\r\n let _object = object;\r\n\r\n let clientInfo = null;\r\n if (_object?.clientInfo) {\r\n clientInfo = checkParseObject(JSON.stringify(_object.clientInfo));\r\n clientInfo.blnIsUserLoggedIn = false;\r\n clientInfo.dtmLastUpdate = getCurrentDate();\r\n clientInfo.dtmLastRequest = getCurrentDate();\r\n }\r\n\r\n let plainTextSessionStorage = recursionResetObject(_object);\r\n\r\n plainTextSessionStorage = { ...plainTextSessionStorage, clientInfo: clientInfo };\r\n plainTextSessionStorage = JSON.stringify(plainTextSessionStorage);\r\n\r\n if (SessionStorageIsEncrypted) {\r\n let cipherTextSessionStorage = String(CryptoJS.AES.encrypt(plainTextSessionStorage, SessionStorageKey));\r\n sessionStorage.setItem(SessionStorageName, cipherTextSessionStorage);\r\n } else {\r\n sessionStorage.setItem(SessionStorageName, plainTextSessionStorage);\r\n }\r\n}\r\n//#endregion\r\n\r\n/////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////\r\n\r\n//#region Html handler functions\r\n\r\nexport const scrollToElement = (path) => {\r\n var offSet = 0;\r\n var scrollType = \"smooth\";\r\n const tesNode = document.querySelector(path);\r\n if (true) {\r\n window.scrollTo({\r\n left: 0,\r\n top: tesNode.offsetTop + offSet,\r\n behavior: scrollType,\r\n });\r\n }\r\n};\r\n\r\nexport const fetchAndDownloadFile = async (fileUrl, fileNameToSave) => {\r\n await fetch(fileUrl)\r\n .then(async (response) => await response.blob())\r\n .then((blob) => {\r\n const link = document.createElement(\"a\");\r\n link.href = URL.createObjectURL(blob);\r\n link.download = fileNameToSave;\r\n link.click();\r\n })\r\n .catch(console.error);\r\n};\r\n\r\nexport function copyTextToClipboard(copyText) {\r\n navigator.clipboard.writeText(copyText);\r\n}\r\n\r\n//#endregion\r\n\r\n/////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////\r\n\r\n//#region resize image\r\nexport async function downloadFile(objFile) {\r\n try {\r\n const element = document.createElement(\"a\");\r\n const file = objFile;\r\n element.href = URL.createObjectURL(file);\r\n element.download = file.name;\r\n document.body.appendChild(element);\r\n element.click();\r\n\r\n return true;\r\n } catch (error) {\r\n console.error(error);\r\n return false;\r\n }\r\n}\r\n\r\n/**\r\n *\r\n * @param {FileList | any[]} lstFileList\r\n * @param {*} intMaxWidth\r\n * @param {*} intMaxHeight\r\n * @param {number} [fltQuality] quality of image max value 1\r\n * @param {boolean} [blnForceResize] force to resize image according to intMaxWidth and intMaxHeight\r\n * @param {\"image/apng\" | \"image/avif\" | \"image/gif\" | \"image/jpeg\" | \"image/png\" | \"image/webp\" | \"image/bmp\" | \"image/x-icon\" | \"image/tiff\"} [strImgType]\r\n * @param {boolean} [blnShowPreview] To show img preview of the result\r\n * @param {boolean} [blnDownloadAfterConvert] Download Each image after convert it.\r\n */\r\nexport async function resizeImg(\r\n lstFileList,\r\n intMaxWidth = 620,\r\n intMaxHeight = 620,\r\n fltQuality = 0.95,\r\n blnForceResize = false,\r\n strImgType = null,\r\n blnShowPreview = false,\r\n blnDownloadAfterConvert = false\r\n) {\r\n try {\r\n let files = lstFileList;\r\n let lstResultFile = [];\r\n\r\n for (var i = 0; i < files.length; i++) {\r\n let strBase64ResizedImg = await processFile(files[i], i, intMaxWidth, intMaxHeight, fltQuality, strImgType, blnForceResize, blnShowPreview); // process each file at once\r\n\r\n if (strBase64ResizedImg) {\r\n let fileNew = await fetch(strBase64ResizedImg);\r\n let blob = await fileNew.blob();\r\n let strFileName = files[i].name;\r\n let strNewFileType = files[i].type;\r\n if (strImgType) {\r\n strFileName = String(files[i].name).split(\".\")[0] + \".\" + String(strImgType).split(\"/\")[1];\r\n strNewFileType = strImgType;\r\n }\r\n\r\n let newObjFile = new File([blob], strFileName, { type: strNewFileType });\r\n lstResultFile.push(newObjFile);\r\n\r\n if (blnDownloadAfterConvert) {\r\n await downloadFile(newObjFile);\r\n }\r\n }\r\n }\r\n\r\n return lstResultFile;\r\n } catch (error) {\r\n console.error(error);\r\n return [];\r\n }\r\n}\r\n\r\n/**\r\n *\r\n * @param {File} objFile\r\n * @param {number} intIndex\r\n * @param {number} intMaxWidth\r\n * @param {number} intMaxHeight\r\n * @param {number} fltQuality\r\n * @param {string} strImgType\r\n * @param {boolean} blnForceResize\r\n * @param {boolean} blnShowPreview\r\n * @returns {Promise}\r\n */\r\nfunction processFile(objFile, intIndex, intMaxWidth, intMaxHeight, fltQuality, strImgType, blnForceResize, blnShowPreview) {\r\n return new Promise((resolve, reject) => {\r\n try {\r\n if (!(window.File && window.FileReader && window.FileList && window.Blob)) {\r\n console.error(\"The File APIs are not fully supported in this browser.\");\r\n resolve(false);\r\n return;\r\n }\r\n\r\n if (!/image/i.test(objFile.type)) {\r\n console.error(\"File \" + objFile.name + \" is not an image.\");\r\n resolve(false);\r\n return;\r\n }\r\n\r\n // read the files\r\n let reader = new FileReader();\r\n reader.readAsArrayBuffer(objFile);\r\n\r\n reader.onload = (event) => {\r\n // blob stuff\r\n var blob = new Blob([event.target.result]); // create blob...\r\n window.URL = window.URL || window.webkitURL;\r\n let blobURL = window.URL.createObjectURL(blob); // and get it's URL\r\n\r\n // helper Image object\r\n let objImg = new Image();\r\n objImg.src = blobURL;\r\n\r\n objImg.onload = () => {\r\n // have to wait till it's loaded\r\n\r\n if (!strImgType) {\r\n strImgType = objFile.type;\r\n }\r\n\r\n let canvas = document.createElement(\"canvas\");\r\n\r\n let width = objImg.width;\r\n let height = objImg.height;\r\n\r\n // calculate the width and height, constraining the proportions\r\n if (blnForceResize) {\r\n width = intMaxWidth;\r\n height = intMaxHeight;\r\n } else {\r\n if (width > height) {\r\n if (width > intMaxWidth) {\r\n //height *= intMaxWidth / width;\r\n height = Math.round((height *= intMaxWidth / width));\r\n width = intMaxWidth;\r\n }\r\n } else {\r\n if (height > intMaxHeight) {\r\n //width *= intMaxHeight / height;\r\n width = Math.round((width *= intMaxHeight / height));\r\n height = intMaxHeight;\r\n }\r\n }\r\n }\r\n\r\n if (!canvas.getContext) {\r\n console.error(\"Canvas are not fully supported in this browser.\");\r\n resolve(false);\r\n return;\r\n }\r\n\r\n // resize the canvas and draw the image data into it\r\n canvas.width = width;\r\n canvas.height = height;\r\n\r\n let ctx = canvas.getContext(\"2d\");\r\n ctx.drawImage(objImg, 0, 0, width, height);\r\n\r\n let dataURL = canvas.toDataURL(strImgType, fltQuality); // get the data from canvas as 70% JPG (can be also PNG, etc.)\r\n\r\n if (blnShowPreview && dataURL) {\r\n let previewImg = document.createElement(\"img\");\r\n previewImg.id = \"previewResizeImg-\" + intIndex;\r\n previewImg.src = dataURL;\r\n previewImg.alt = \"\";\r\n document.body.appendChild(previewImg);\r\n }\r\n\r\n resolve(dataURL);\r\n\r\n canvas.onerror = (error) => {\r\n console.error(`Error occurred while canvas initialized.\\n${error.toString()}`);\r\n resolve(false);\r\n };\r\n };\r\n\r\n objImg.onerror = () => {\r\n console.error(`Error occurred when loading image: ${objFile.name}.`);\r\n resolve(false);\r\n };\r\n };\r\n\r\n reader.onerror = (error) => {\r\n console.error(`Error occurred reading file: ${objFile.name}.\\n${error.target.error}`);\r\n resolve(false);\r\n };\r\n } catch (error) {\r\n console.error(error);\r\n resolve(false);\r\n }\r\n });\r\n}\r\n\r\n//#region util func\r\n\r\nexport function parseArabicNumber(str) {\r\n let number = str;\r\n try {\r\n number = String(\r\n str\r\n .replace(/[٠١٢٣٤٥٦٧٨٩]/g, function (d) {\r\n return d.charCodeAt(0) - 1632; // Convert Arabic numbers\r\n })\r\n .replace(\r\n /[۰۱۲۳۴۵۶۷۸۹]/g,\r\n function (d) {\r\n return d.charCodeAt(0) - 1776; // Convert Persian numbers\r\n },\r\n 10000000000\r\n )\r\n );\r\n return number;\r\n } catch {\r\n return str;\r\n }\r\n}\r\n\r\nexport function camelize(str, blnClassName = false) {\r\n return str.replace(/(?:^\\w|[A-Z]|\\b\\w|\\s+)/g, function (match, index) {\r\n if (+match === 0) return \"\"; // or if (/\\s+/.test(match)) for white spaces\r\n return index === 0 ? (blnClassName ? match.toUpperCase() : match.toLowerCase()) : match.toUpperCase();\r\n });\r\n}\r\n\r\nexport function normalizeText(str) {\r\n return str.replace(/(?:^\\w|[A-Z]|\\b\\w|\\s+)/g, function (match, index) {\r\n if (+match === 0) return \"\"; // or if (/\\s+/.test(match)) for white spaces\r\n return index === 0 ? match.toLowerCase() : match.toLowerCase();\r\n });\r\n}\r\n\r\nexport const getKeyByValue = (obj, value) => Object.keys(obj).find((key) => obj[key] === value);\r\n\r\n/**\r\n *\r\n * @param {\"datetime\" | \"date\"} type\r\n */\r\nexport function convertDateToInputForm(date, type) {\r\n try {\r\n if (type === \"datetime\") {\r\n let dtmInput = new Date(date);\r\n dtmInput.setMinutes(dtmInput.getMinutes() - dtmInput.getTimezoneOffset());\r\n let strInputDate = dtmInput.toISOString().slice(0, 16);\r\n return strInputDate;\r\n } else {\r\n let dtmInput = new Date(date);\r\n let strInputDate = dtmInput.toISOString().slice(0, 10);\r\n return strInputDate;\r\n }\r\n } catch {\r\n if (type === \"datetime\") {\r\n let dtmInput = new Date();\r\n dtmInput.setMinutes(dtmInput.getMinutes() - dtmInput.getTimezoneOffset());\r\n let strInputDate = dtmInput.toISOString().slice(0, 16);\r\n return strInputDate;\r\n } else {\r\n let dtmInput = new Date();\r\n let strInputDate = dtmInput.toISOString().slice(0, 10);\r\n return strInputDate;\r\n }\r\n }\r\n}\r\n\r\nexport function searchThrowAppCategory(objCategory, id_or_name) {\r\n try {\r\n let result = {};\r\n let lstCat = Object.entries(objCategory);\r\n\r\n for (let i = 0; i < lstCat.length; i++) {\r\n let [key, value] = lstCat[i];\r\n\r\n if (key === \"id\" || key === \"value\") {\r\n continue;\r\n }\r\n\r\n if (!Number.isNaN(Number(id_or_name))) {\r\n if (String(value?.id) === String(id_or_name)) {\r\n result = value?.value;\r\n break;\r\n }\r\n } else {\r\n if (String(key) === String(id_or_name)) {\r\n result = value?.value;\r\n break;\r\n }\r\n }\r\n }\r\n\r\n return result;\r\n } catch {\r\n return {};\r\n }\r\n}\r\n\r\n//#endregion\r\nexport const generateRandomString = (length) => {\r\n let result = \"\";\r\n const characters = \"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789\";\r\n const charactersLength = characters.length;\r\n for (let i = 0; i < length; i++) {\r\n result += characters.charAt(Math.floor(Math.random() * charactersLength));\r\n }\r\n return result;\r\n};\r\n\r\nexport const generateRandomStringSecure = (length) => {\r\n const characters = \"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789\";\r\n const charactersLength = characters.length;\r\n let result = \"\";\r\n\r\n // Create an array of 32-bit unsigned integers\r\n const randomValues = new Uint32Array(length);\r\n\r\n // Generate random values\r\n window.crypto.getRandomValues(randomValues);\r\n randomValues.forEach((value) => {\r\n result += characters.charAt(value % charactersLength);\r\n });\r\n return result;\r\n};\r\n\r\nexport function getRandomNumberSecure(length) {\r\n const characters = \"0123456789\";\r\n const charactersLength = characters.length;\r\n\r\n let result = \"\";\r\n\r\n // Create an array of 32-bit unsigned integers\r\n const randomValues = new Uint32Array(length);\r\n\r\n // Generate random values\r\n window.crypto.getRandomValues(randomValues);\r\n randomValues.forEach((value, index) => {\r\n let char = characters.charAt(value % charactersLength);\r\n if (index === 0 && char === \"0\") {\r\n char = \"1\";\r\n }\r\n result += char;\r\n });\r\n return Number(result);\r\n}\r\n\r\nexport function fetchFileFromUrlAndDownload(url, strDownloadName) {\r\n // (A) FETCH FILE\r\n fetch(url)\r\n // (B) RETURN AS BLOB\r\n .then((res) => {\r\n if (res.status != 200) {\r\n throw new Error(\"Bad server response\");\r\n }\r\n return res.blob();\r\n })\r\n\r\n // (C) BLOB DATA\r\n .then((data) => {\r\n // (C1) \"FORCE DOWNLOAD\"\r\n var url = window.URL.createObjectURL(data),\r\n anchor = document.createElement(\"a\");\r\n anchor.href = url;\r\n anchor.download = strDownloadName;\r\n anchor.click();\r\n\r\n // (C2) CLEAN UP\r\n window.URL.revokeObjectURL(url);\r\n document.removeChild(anchor);\r\n })\r\n\r\n // (D) HANDLE ERRORS - OPTIONAL\r\n .catch((err) => console.error(err));\r\n}\r\n\r\n/**\r\n * To compress text\r\n * @param {object} strPlaintText\r\n * @returns {string}\r\n */\r\nexport function compressText(strPlaintText) {\r\n try {\r\n return lzString.compressToUTF16(JSON.stringify(strPlaintText));\r\n } catch {\r\n return null;\r\n }\r\n}\r\n\r\nexport function resolveStringToObject(path, obj) {\r\n try {\r\n return path.split(\".\").reduce(function (prev, curr) {\r\n return prev ? prev[curr] : null;\r\n }, obj);\r\n } catch {\r\n return null;\r\n }\r\n}\r\n\r\n/**\r\n * To decompress text\r\n * @param {string} strCompressedText\r\n */\r\nexport function decompressText(strCompressedText) {\r\n try {\r\n return JSON.parse(lzString.decompressFromUTF16(strCompressedText));\r\n } catch {\r\n return null;\r\n }\r\n}\r\n\r\nexport function getCategoryCache(getAppLocalStorage, path = null) {\r\n try {\r\n let result = decompressText(getAppLocalStorage());\r\n return resolveStringToObject(path || \"clientInfo.objCatInfo\", result);\r\n } catch {\r\n return {};\r\n }\r\n}\r\n\r\nexport function getLoginDeviceInfo(ua) {\r\n let parser = new UAParser(ua);\r\n\r\n return `${parser?.getOS()?.name || \"\"} ${parser?.getOS()?.version || \"\"} - ${parser?.getBrowser()?.name || \"\"} ${parser?.getBrowser()?.version || \"\"}`;\r\n}\r\n\r\n\r\nexport function categoryGetValue(objCategory, id_or_name, strMiddleKey = null, blnIsParentKey = false) {\r\n try {\r\n let result = {};\r\n let lstCat = Object.entries(objCategory);\r\n\r\n for (let i = 0; i < lstCat.length; i++) {\r\n let [key, value] = lstCat[i];\r\n if (key === \"id\" || key === \"value\") {\r\n continue;\r\n }\r\n\r\n if (strMiddleKey) {\r\n if (blnIsParentKey) {\r\n if (!Number.isNaN(Number(id_or_name))) {\r\n if (String(id_or_name) !== String(value?.id)) {\r\n continue;\r\n } else {\r\n result = value?.[strMiddleKey]?.value;\r\n break;\r\n }\r\n }\r\n }\r\n\r\n value = value?.[strMiddleKey];\r\n }\r\n\r\n if (!Number.isNaN(Number(id_or_name))) {\r\n if (String(value?.id) === String(id_or_name)) {\r\n result = value?.value;\r\n break;\r\n }\r\n } else {\r\n if (String(key) === String(id_or_name)) {\r\n result = value?.value;\r\n break;\r\n }\r\n }\r\n }\r\n\r\n return result;\r\n } catch {\r\n return {};\r\n }\r\n}\r\n\r\nexport function categoryGetKey(objCategory, id_or_name) {\r\n try {\r\n let result = null;\r\n let lstCat = Object.entries(objCategory);\r\n\r\n for (let i = 0; i < lstCat.length; i++) {\r\n let [key, value] = lstCat[i];\r\n\r\n if (key === \"id\" || key === \"value\") {\r\n continue;\r\n }\r\n\r\n if (!Number.isNaN(Number(id_or_name))) {\r\n if (String(value?.id) === String(id_or_name)) {\r\n result = key;\r\n break;\r\n }\r\n } else {\r\n if (String(key) === String(id_or_name)) {\r\n result = value?.id;\r\n break;\r\n }\r\n }\r\n }\r\n\r\n return result;\r\n } catch {\r\n return null;\r\n }\r\n}","\r\nexport function ViewAlert(strMessage,App_IsInTestingMode) {\r\n if (App_IsInTestingMode) {\r\n alert(strMessage);\r\n }\r\n}\r\n\r\nexport function ThrowError(error,App_IsInTestingMode) {\r\n if (App_IsInTestingMode) {\r\n throw new Error(error);\r\n }\r\n}\r\n\r\nexport function logMessage(strPageName, strTitle, strMessage,App_IsInTestingMode) {\r\n if (App_IsInTestingMode) {\r\n console.log(\" \");\r\n console.log(strPageName + \"*------------------(\" + strTitle + \")----------------------------\");\r\n console.log(\"*\");\r\n console.log(strMessage);\r\n console.log(\"*\");\r\n console.log(\"**********************************************************************************************************\");\r\n console.log(\" \");\r\n }\r\n}\r\n\r\n\r\nexport function logError(strPageName, strTitle, strMessage,App_IsInTestingMode) {\r\n if (App_IsInTestingMode) {\r\n console.log(\" \");\r\n console.error(strPageName + \"*------------------(\" + strTitle + \")----------------------------\");\r\n console.log(\"*\");\r\n console.error(strMessage);\r\n console.log(\"*\");\r\n console.log(\"**********************************************************************************************************\");\r\n console.log(\" \");\r\n }\r\n}\r\n\r\n\r\n","import CryptoJS from \"crypto-js\";\r\nimport * as appFunctions from \"../cbmisFunction\";\r\n\r\n//#region graphql fetch data\r\n/**\r\n *\r\n * @param {string} strURL\r\n * @param {{appName?:string, tableName?:string, queryName?:string, queryBody?: (tableName, objectInput, objectCondition, arrAttributes)=>string, objectInput?: object, objectCondition?: object, arrAttributes?: string[],appState?:any}} objRequestQuery\r\n * @param {{token?:string, bigUserID: number, bigUserRoleID: number, bigFeatureID: number }} strRequester\r\n * @param {{blnIsTestingMode?:boolean, strPageInfo?:string, blnIsLocalStorageEncrypted?: boolean, strLocalStorageEncryptKey?: string, signal?: AbortSignal, blnEncryptRes?: boolean, strEncryptResKey?: string, blnEncryptReq?: boolean, blnIncludeCredentials?: boolean}} [objTestingConfig]\r\n * @returns\r\n */\r\nexport async function fetchData(strURL, objRequestQuery, strRequester, objTestingConfig = { blnIsTestingMode: true, strPageInfo: \"\", blnIsLocalStorageEncrypted: false, strLocalStorageEncryptKey: \"secret\", signal: null, blnEncryptRes: false, strEncryptResKey: \"secret\", blnEncryptReq: false, blnIncludeCredentials: false }) {\r\n try {\r\n if (!objTestingConfig?.strPageInfo) {\r\n objTestingConfig.strPageInfo = \"\";\r\n }\r\n if (!objTestingConfig?.blnIsLocalStorageEncrypted) {\r\n objTestingConfig.blnIsLocalStorageEncrypted = false;\r\n }\r\n if (!objTestingConfig?.strLocalStorageEncryptKey) {\r\n objTestingConfig.strLocalStorageEncryptKey = \"secret\";\r\n }\r\n if (!objTestingConfig?.blnEncryptRes) {\r\n objTestingConfig.blnEncryptRes = false;\r\n }\r\n if (!objTestingConfig?.strEncryptResKey) {\r\n objTestingConfig.strEncryptResKey = \"secret\";\r\n }\r\n\r\n let tableNameQur = objRequestQuery?.tableName;\r\n let objectInputQur = JSON.stringify(objRequestQuery?.objectInput);\r\n let objectConditionQur = JSON.stringify(objRequestQuery?.objectCondition);\r\n let arrAttributesQur = JSON.stringify(objRequestQuery?.arrAttributes);\r\n\r\n if (objTestingConfig.blnIsTestingMode) {\r\n console.log(\" \");\r\n console.log(objTestingConfig.strPageInfo + \"*------------------( \" + objRequestQuery.tableName + \"-\" + objRequestQuery.queryName + \"-Query )----------------------------\");\r\n console.log(\"*\");\r\n console.log(objRequestQuery.queryBody(tableNameQur, objectInputQur, objectConditionQur, arrAttributesQur));\r\n console.log(\"*\");\r\n console.log(\"**********************************************************************************************************\");\r\n console.log(\" \");\r\n }\r\n\r\n let objReqCounter = null;\r\n if (localStorage.hasOwnProperty(\"SRPM\") && localStorage.getItem(\"SRPM\") !== null) {\r\n objReqCounter = getAppLocalStorage(\"SRPM\", objTestingConfig?.blnIsLocalStorageEncrypted, objTestingConfig?.strLocalStorageEncryptKey);\r\n }\r\n\r\n if (!objReqCounter || !objReqCounter?.rqNb || !objReqCounter?.lasR || !objReqCounter?.rqTM) {\r\n objReqCounter = {\r\n rqNb: 1,\r\n rqTM: new Date().toUTCString(),\r\n lasR: new Date().toUTCString(),\r\n };\r\n } else {\r\n if (getDifferenceBetweenTwoDate(objReqCounter.lasR, new Date().toUTCString(), \"minute\") > 1) {\r\n objReqCounter = {\r\n rqNb: 1,\r\n rqTM: new Date().toUTCString(),\r\n lasR: new Date().toUTCString(),\r\n };\r\n } else {\r\n ++objReqCounter.rqNb;\r\n objReqCounter.rqTM = new Date().toUTCString();\r\n }\r\n }\r\n\r\n setAppLocalStorage(objReqCounter, \"SRPM\", objTestingConfig?.blnIsLocalStorageEncrypted, objTestingConfig?.strLocalStorageEncryptKey);\r\n\r\n let header = new Headers();\r\n header.append(\"Content-Type\", \"application/json; charset=utf-8\");\r\n if (!strRequester?.token) {\r\n strRequester.token = generatePatternID();\r\n }\r\n header.append(\"Authorization\", `Bearer ${strRequester.token}`);\r\n\r\n if (objTestingConfig?.blnEncryptRes) {\r\n tableNameQur = encryptTextRabbit(String(tableNameQur), objTestingConfig?.strEncryptResKey);\r\n objectInputQur = encryptTextRabbit(String(objectInputQur), objTestingConfig?.strEncryptResKey);\r\n objectConditionQur = encryptTextRabbit(String(objectConditionQur), objTestingConfig?.strEncryptResKey);\r\n arrAttributesQur = encryptTextRabbit(String(arrAttributesQur), objTestingConfig?.strEncryptResKey);\r\n }\r\n const strQueryBody = objRequestQuery.queryBody(tableNameQur, objectInputQur, objectConditionQur, arrAttributesQur);\r\n const strRequesterBody = `${objRequestQuery.appName}*-$-*${objRequestQuery.tableName}*-$-*${objRequestQuery.queryName}*-$-*${strRequester.bigUserID}*-$-*${strRequester.bigUserRoleID}*-$-*${strRequester.bigFeatureID}*-$-*${objReqCounter.rqNb}*-$-*${objReqCounter.rqTM}`;\r\n const bodyPlain = JSON.stringify({ query: strQueryBody, strRequester: strRequesterBody });\r\n\r\n let objBodyStr = bodyPlain;\r\n if (objTestingConfig?.blnEncryptReq) {\r\n const bodyCyberKey = generateRandomStringSecure(4);\r\n const bodyCyberHash = CryptoJS.SHA3(bodyPlain, { outputLength: 224 }).toString(CryptoJS.enc.Base64);\r\n const bodyCyber = JSON.stringify({\r\n datac: bodyCyberHash + \".\" + bodyCyberKey + encryptTextRabbit(bodyPlain, bodyCyberKey) + \"sec\",\r\n });\r\n objBodyStr = bodyCyber;\r\n }\r\n\r\n if (objTestingConfig?.blnIncludeCredentials) {\r\n header.append(\"Access-Control-Allow-Origin\", new URL(strURL).origin);\r\n }\r\n\r\n const res = await fetch(strURL, {\r\n method: \"POST\",\r\n ...(objTestingConfig?.signal ? { signal: objTestingConfig.signal } : {}),\r\n credentials: objTestingConfig?.blnIncludeCredentials ? \"include\" : \"same-origin\",\r\n headers: header,\r\n body: objBodyStr,\r\n });\r\n\r\n const json = await res.json();\r\n let response = json?.data?.[objRequestQuery.queryName];\r\n\r\n if (!response) {\r\n response = { ...response };\r\n }\r\n\r\n if (objTestingConfig?.blnEncryptRes) {\r\n response.serverResponse = decryptTextRabbit(String(response?.serverResponse), objTestingConfig?.strEncryptResKey);\r\n }\r\n response.serverResponse = appFunctions.checkParseObject(response?.serverResponse);\r\n\r\n if (objTestingConfig.blnIsTestingMode) {\r\n console.log(\" \");\r\n console.log(objTestingConfig.strPageInfo + \"*------------------( \" + objRequestQuery.tableName + \"-\" + objRequestQuery.queryName + \"-Response )----------------------------\");\r\n console.log(\"*\");\r\n console.log(response);\r\n console.log(\"*\");\r\n console.log(\"**********************************************************************************************************\");\r\n console.log(\" \");\r\n }\r\n\r\n if (response.serverResponse?.error) {\r\n return {\r\n blnIsRequestSuccessful: response?.blnIsRequestSuccessful ? true : false,\r\n response: response?.serverResponse?.error,\r\n };\r\n }\r\n\r\n if (!response?.serverResponse && !response?.blnIsRequestSuccessful) {\r\n return { blnIsRequestSuccessful: false, response: \"Server sent an empty response.\" };\r\n }\r\n\r\n return { blnIsRequestSuccessful: response?.blnIsRequestSuccessful ? true : false, response: response?.serverResponse };\r\n } catch (error) {\r\n if (objTestingConfig.blnIsTestingMode) {\r\n console.log(\" \");\r\n console.log(objTestingConfig.strPageInfo + \"*------------------( Error Fetch Data )----------------------------\");\r\n console.log(\"*\");\r\n console.error(error);\r\n console.log(\"*\");\r\n console.log(\"**********************************************************************************************************\");\r\n console.log(\" \");\r\n }\r\n\r\n if (objTestingConfig.blnIsTestingMode) {\r\n return { blnIsRequestSuccessful: false, response: error instanceof SyntaxError ? \"Server block the request.\" : error?.message ? error?.message : error };\r\n } else {\r\n return {\r\n blnIsRequestSuccessful: false,\r\n response: \"Sorry, we can`t process your request at this time, Please check you internet connection then try again.\",\r\n };\r\n }\r\n }\r\n}\r\n\r\n//#endregion\r\n\r\n//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////\r\n\r\n//#region upload function\r\n/**\r\n * @param {string} strUploadFileLink\r\n * @param {Array.<{fileType, fileNewName, fileOriginalName, fileSizeByte, subDirPath}>} userData\r\n * @param {FileList | any[]} userFiles\r\n * @param {{appName:string, queryName:string, bigUserID, bigUserRoleID, bigFeatureID, token?}} strRequester\r\n * @param {{blnIsTestingMode?: boolean, strPageInfo?:string, blnIsLocalStorageEncrypted?: boolean, strLocalStorageEncryptKey?: string, signal?: AbortSignal, blnIsServerFile?: boolean, blnEncryptReq?: boolean, blnIncludeCredentials?: boolean }} objTestingConfig\r\n */\r\nasync function fetchFiles(strUploadFileLink, userData, userFiles, strRequester, objTestingConfig = { blnIsTestingMode: true, strPageInfo: \"\", blnIsLocalStorageEncrypted: false, strLocalStorageEncryptKey: \"secret\", signal: null, blnEncryptReq: false, blnIncludeCredentials: false }) {\r\n try {\r\n if (!objTestingConfig?.strPageInfo) {\r\n objTestingConfig.strPageInfo = \"\";\r\n }\r\n\r\n if (!objTestingConfig?.blnIsLocalStorageEncrypted) {\r\n objTestingConfig.blnIsLocalStorageEncrypted = false;\r\n }\r\n if (!objTestingConfig?.strLocalStorageEncryptKey) {\r\n objTestingConfig.strLocalStorageEncryptKey = \"secret\";\r\n }\r\n if (!objTestingConfig?.blnIsServerFile) {\r\n objTestingConfig.blnIsServerFile = false;\r\n }\r\n\r\n let objReqCounter = null;\r\n if (localStorage.hasOwnProperty(\"SRPM\") && localStorage.getItem(\"SRPM\") !== null) {\r\n objReqCounter = getAppLocalStorage(\"SRPM\", objTestingConfig?.blnIsLocalStorageEncrypted, objTestingConfig?.strLocalStorageEncryptKey);\r\n }\r\n\r\n if (!objReqCounter || !objReqCounter?.rqNb || !objReqCounter?.lasR || !objReqCounter?.rqTM) {\r\n objReqCounter = {\r\n rqNb: 1,\r\n rqTM: new Date().toUTCString(),\r\n lasR: new Date().toUTCString(),\r\n };\r\n } else {\r\n if (getDifferenceBetweenTwoDate(objReqCounter.lasR, new Date().toUTCString(), \"minute\") > 1) {\r\n objReqCounter = {\r\n rqNb: 1,\r\n rqTM: new Date().toUTCString(),\r\n lasR: new Date().toUTCString(),\r\n };\r\n } else {\r\n ++objReqCounter.rqNb;\r\n objReqCounter.rqTM = new Date().toUTCString();\r\n }\r\n }\r\n\r\n setAppLocalStorage(objReqCounter, \"SRPM\", objTestingConfig?.blnIsLocalStorageEncrypted, objTestingConfig?.strLocalStorageEncryptKey);\r\n\r\n let header = new Headers();\r\n header.append(\"Accept\", \"application/json\");\r\n header.append(\"cbmis-auth-data-op\", \"file\");\r\n\r\n if (objTestingConfig?.blnIsServerFile) {\r\n header.append(\"cbmis-client-data-op\", \"file\");\r\n }\r\n\r\n if (!strRequester?.token) {\r\n strRequester.token = generatePatternID();\r\n }\r\n header.append(\"Authorization\", `Bearer ${strRequester.token}`);\r\n if (objTestingConfig?.blnIncludeCredentials) {\r\n header.append(\"Access-Control-Allow-Origin\", new URL(strUploadFileLink).origin);\r\n }\r\n const formData = new FormData();\r\n\r\n const strRequesterBody = `${strRequester.appName}*-$-*uploadFile*-$-*${strRequester.queryName}*-$-*${strRequester.bigUserID}*-$-*${strRequester.bigUserRoleID}*-$-*${strRequester.bigFeatureID}*-$-*${objReqCounter.rqNb}*-$-*${objReqCounter.rqTM}`;\r\n const objUserDataStr = JSON.stringify(userData);\r\n\r\n if (objTestingConfig?.blnEncryptReq) {\r\n let bodyPlain = JSON.stringify({\r\n strRequester: strRequesterBody,\r\n userData: objUserDataStr,\r\n });\r\n\r\n const bodyCyberKey = generateRandomStringSecure(4);\r\n const bodyCyberHash = CryptoJS.SHA3(bodyPlain, { outputLength: 224 }).toString(CryptoJS.enc.Base64);\r\n const bodyCyber = bodyCyberHash + \".\" + bodyCyberKey + encryptTextRabbit(bodyPlain, bodyCyberKey) + \"sec\";\r\n formData.append(\"datac\", bodyCyber);\r\n } else {\r\n formData.append(\"strRequester\", strRequesterBody);\r\n formData.append(\"userData\", objUserDataStr);\r\n }\r\n\r\n Array.from(userFiles || []).forEach((file) => {\r\n formData.append(\"userFiles\", file);\r\n });\r\n\r\n const res = await fetch(strUploadFileLink, {\r\n method: \"POST\",\r\n ...(objTestingConfig?.signal ? { signal: objTestingConfig.signal } : {}),\r\n credentials: objTestingConfig?.blnIncludeCredentials ? \"include\" : \"same-origin\",\r\n headers: header,\r\n body: formData,\r\n });\r\n const json = await res.json();\r\n\r\n if (objTestingConfig?.blnIsTestingMode) {\r\n console.log(\" \");\r\n console.log(objTestingConfig?.strPageInfo + \"*------------------( UploadFile-Response )----------------------------\");\r\n console.log(\"*\");\r\n console.log(json?.response);\r\n console.log(\"*\");\r\n console.log(\"**********************************************************************************************************\");\r\n console.log(\" \");\r\n }\r\n\r\n if (json?.error) {\r\n if (objTestingConfig?.blnIsTestingMode) {\r\n console.log(\" \");\r\n console.log(objTestingConfig?.strPageInfo + \"*------------------( [ERROR] )----------------------------\");\r\n console.log(\"*\");\r\n console.error(json?.error);\r\n console.log(\"*\");\r\n console.log(\"**********************************************************************************************************\");\r\n console.log(\" \");\r\n }\r\n }\r\n\r\n return json;\r\n } catch (error) {\r\n if (objTestingConfig?.blnIsTestingMode) {\r\n console.log(\" \");\r\n console.log(objTestingConfig?.strPageInfo + \"*------------------( Error Fetch File )----------------------------\");\r\n console.log(\"*\");\r\n console.error(error);\r\n console.log(\"*\");\r\n console.log(\"**********************************************************************************************************\");\r\n console.log(\" \");\r\n }\r\n\r\n if (objTestingConfig?.blnIsTestingMode) {\r\n return { error: error instanceof SyntaxError ? \"Server block the request.\" : error?.message ? error?.message : error };\r\n } else {\r\n return {\r\n error: \"Sorry, we can`t process your request at this time, Please check you internet connection then try again.\",\r\n };\r\n }\r\n }\r\n}\r\n\r\n/**\r\n *\r\n * @param {string} strUploadFileLink\r\n * @param {FileList} lstFiles\r\n * @param {string} fileType\r\n * @param {string} subDirPath\r\n * @param {{appName:string, queryName:string, bigUserID, bigUserRoleID, bigFeatureID, token?}} strRequester\r\n * @param {{blnIsMultiFile?:boolean, newFileName?: string | string[] , blnReturnFullResponse?:boolean}} objUploadConfig\r\n * @param {{blnIsTestingMode?: boolean, strPageInfo?:string, blnIsLocalStorageEncrypted?: boolean, strLocalStorageEncryptKey?: string, signal?: AbortSignal, blnIsServerFile?:boolean, blnEncryptReq?: boolean, blnIncludeCredentials?: boolean }} objTestingConfig\r\n * @returns\r\n */\r\nexport async function uploadFile(\r\n strUploadFileLink,\r\n lstFiles,\r\n fileType,\r\n subDirPath = null,\r\n strRequester,\r\n objUploadConfig = { blnIsMultiFile: true, newFileName: undefined, blnReturnFullResponse: true },\r\n objTestingConfig = {\r\n blnIsTestingMode: true,\r\n strPageInfo: \"\",\r\n blnIsLocalStorageEncrypted: false,\r\n strLocalStorageEncryptKey: \"secret\",\r\n signal: null,\r\n blnIsServerFile: false,\r\n blnEncryptReq: false,\r\n blnIncludeCredentials: false,\r\n }\r\n) {\r\n if (!objUploadConfig || typeof objUploadConfig !== \"object\") {\r\n objUploadConfig = {};\r\n }\r\n\r\n if (objUploadConfig?.blnIsMultiFile === undefined || objUploadConfig?.blnIsMultiFile === null) {\r\n objUploadConfig.blnIsMultiFile = false;\r\n }\r\n\r\n if (objUploadConfig?.blnReturnFullResponse === undefined || objUploadConfig?.blnReturnFullResponse === null) {\r\n objUploadConfig.blnReturnFullResponse = true;\r\n }\r\n\r\n if (!objTestingConfig?.strPageInfo) {\r\n objTestingConfig.strPageInfo = \"\";\r\n }\r\n\r\n if (!objTestingConfig?.blnIsLocalStorageEncrypted) {\r\n objTestingConfig.blnIsLocalStorageEncrypted = false;\r\n }\r\n if (!objTestingConfig?.strLocalStorageEncryptKey) {\r\n objTestingConfig.strLocalStorageEncryptKey = \"secret\";\r\n }\r\n if (!objTestingConfig?.blnIsServerFile) {\r\n objTestingConfig.blnIsServerFile = false;\r\n }\r\n\r\n try {\r\n let userData = [];\r\n let userFiles = [];\r\n Array.from(lstFiles || []).forEach((file, intIndex) => {\r\n let newFileName = !objUploadConfig?.newFileName ? null : objUploadConfig?.newFileName;\r\n\r\n if (Array.isArray(newFileName)) {\r\n if (newFileName.length !== lstFiles.length) {\r\n newFileName = null;\r\n } else {\r\n newFileName = objUploadConfig?.newFileName?.[intIndex];\r\n }\r\n }\r\n\r\n let currentFile = file;\r\n\r\n userFiles.push(currentFile);\r\n\r\n userData.push({\r\n fileType: fileType, //!!IMPORTANT upload type goes here\r\n subDirPath: !subDirPath ? \"\" : subDirPath,\r\n fileNewName: newFileName ? newFileName : currentFile.name,\r\n fileOriginalName: currentFile.name,\r\n fileSizeByte: currentFile.size,\r\n });\r\n });\r\n\r\n if (objTestingConfig?.blnIsTestingMode) {\r\n console.log(\" \");\r\n console.log(objTestingConfig?.strPageInfo + \"*------------------( userFiles )----------------------------\");\r\n console.log(\"*\");\r\n console.log(userFiles);\r\n console.log(\"*\");\r\n console.log(\"**********************************************************************************************************\");\r\n console.log(\" \");\r\n }\r\n\r\n if (objTestingConfig?.blnIsTestingMode) {\r\n console.log(\" \");\r\n console.log(objTestingConfig?.strPageInfo + \"*------------------( userData )----------------------------\");\r\n console.log(\"*\");\r\n console.log(userData);\r\n console.log(\"*\");\r\n console.log(\"**********************************************************************************************************\");\r\n console.log(\" \");\r\n }\r\n\r\n const response = await fetchFiles(strUploadFileLink, userData, userFiles, strRequester, objTestingConfig);\r\n if (!response || response === undefined || response === null || response?.error || !Array.isArray(response?.response)) {\r\n return false;\r\n }\r\n const result = response?.response;\r\n let blnIsSaved = true;\r\n for (let i = 0; i < result.length; i++) {\r\n if (String(result[i].isSaved) !== String(true)) {\r\n blnIsSaved = false;\r\n break;\r\n }\r\n }\r\n\r\n if (!blnIsSaved) {\r\n return false;\r\n }\r\n\r\n let strFileNameInDB = result;\r\n if (!objUploadConfig?.blnReturnFullResponse) {\r\n strFileNameInDB = result[0].fileNameToSaveInDB;\r\n }\r\n\r\n if (objUploadConfig?.blnIsMultiFile) {\r\n let lstTmp = [];\r\n\r\n for (let i = 0; i < result.length; i++) {\r\n if (!objUploadConfig?.blnReturnFullResponse) {\r\n lstTmp.push(result[i].fileNameToSaveInDB);\r\n } else {\r\n lstTmp.push(result[i]);\r\n }\r\n strFileNameInDB = lstTmp;\r\n }\r\n }\r\n\r\n return strFileNameInDB;\r\n } catch (error) {\r\n if (objTestingConfig.blnIsTestingMode) {\r\n console.log(\" \");\r\n console.log(objTestingConfig?.strPageInfo + \"*------------------( uploadFile-ERROR )----------------------------\");\r\n console.log(\"*\");\r\n console.error(error);\r\n console.log(\"*\");\r\n console.log(\"**********************************************************************************************************\");\r\n console.log(\" \");\r\n }\r\n\r\n return false;\r\n }\r\n}\r\n//#endregion\r\n\r\n//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////\r\n\r\n//#region fetch restful function\r\nexport async function fetchPostRestful(strURL, objBody, strRequester, objTestingConfig = { blnIsTestingMode: true, strPageInfo: \"\", blnIsLocalStorageEncrypted: false, strLocalStorageEncryptKey: \"secret\", signal: null, blnEncryptReq: false, blnIncludeCredentials: false }) {\r\n try {\r\n if (!objTestingConfig?.strPageInfo) {\r\n objTestingConfig.strPageInfo = \"\";\r\n }\r\n if (!objTestingConfig?.blnIsLocalStorageEncrypted) {\r\n objTestingConfig.blnIsLocalStorageEncrypted = false;\r\n }\r\n if (!objTestingConfig?.strLocalStorageEncryptKey) {\r\n objTestingConfig.strLocalStorageEncryptKey = \"secret\";\r\n }\r\n\r\n if (objTestingConfig.blnIsTestingMode) {\r\n console.log(\" \");\r\n console.log(objTestingConfig.strPageInfo + \"*------------------( routingPath\" + strRequester.routingPath + \" )----------------------------\");\r\n console.log(\"*\");\r\n console.log(objBody);\r\n console.log(\"*\");\r\n console.log(\"**********************************************************************************************************\");\r\n console.log(\" \");\r\n }\r\n\r\n let objReqCounter = null;\r\n if (localStorage.hasOwnProperty(\"SRPM\") && localStorage.getItem(\"SRPM\") !== null) {\r\n objReqCounter = getAppLocalStorage(\"SRPM\", objTestingConfig?.blnIsLocalStorageEncrypted, objTestingConfig?.strLocalStorageEncryptKey);\r\n }\r\n\r\n if (!objReqCounter || !objReqCounter?.rqNb || !objReqCounter?.lasR || !objReqCounter?.rqTM) {\r\n objReqCounter = {\r\n rqNb: 1,\r\n rqTM: new Date().toUTCString(),\r\n lasR: new Date().toUTCString(),\r\n };\r\n } else {\r\n if (getDifferenceBetweenTwoDate(objReqCounter.lasR, new Date().toUTCString(), \"minute\") > 1) {\r\n objReqCounter = {\r\n rqNb: 1,\r\n rqTM: new Date().toUTCString(),\r\n lasR: new Date().toUTCString(),\r\n };\r\n } else {\r\n ++objReqCounter.rqNb;\r\n objReqCounter.rqTM = new Date().toUTCString();\r\n }\r\n }\r\n\r\n setAppLocalStorage(objReqCounter, \"SRPM\", objTestingConfig?.blnIsLocalStorageEncrypted, objTestingConfig?.strLocalStorageEncryptKey);\r\n\r\n let header = new Headers();\r\n header.append(\"Content-Type\", \"application/json; charset=utf-8\");\r\n if (strRequester?.token) {\r\n header.append(\"Authorization\", `Bearer ${strRequester.token}`);\r\n } else {\r\n strRequester.token = generatePatternID();\r\n header.append(\"Authorization\", `Bearer ${strRequester.token}`);\r\n }\r\n if (objTestingConfig?.blnIncludeCredentials) {\r\n header.append(\"Access-Control-Allow-Origin\", new URL(strURL).origin);\r\n }\r\n\r\n const strRequesterBody = `${strRequester.appName}*-$-*routingPath*-$-*${strRequester.routingPath}*-$-*${strRequester.bigUserID}*-$-*${strRequester.bigUserRoleID}*-$-*${strRequester.bigFeatureID}*-$-*${objReqCounter.rqNb}*-$-*${objReqCounter.rqTM}`;\r\n const bodyPlain = JSON.stringify({ ...objBody, strRequester: strRequesterBody });\r\n\r\n let objBodyStr = bodyPlain;\r\n if (objTestingConfig?.blnEncryptReq) {\r\n const bodyCyberKey = generateRandomStringSecure(4);\r\n const bodyCyberHash = CryptoJS.SHA3(bodyPlain, { outputLength: 224 }).toString(CryptoJS.enc.Base64);\r\n const bodyCyber = JSON.stringify({\r\n datac: bodyCyberHash + \".\" + bodyCyberKey + encryptTextRabbit(bodyPlain, bodyCyberKey) + \"sec\",\r\n });\r\n objBodyStr = bodyCyber;\r\n }\r\n\r\n const res = await fetch(strURL, {\r\n method: \"POST\",\r\n ...(objTestingConfig?.signal ? { signal: objTestingConfig.signal } : {}),\r\n credentials: objTestingConfig?.blnIncludeCredentials ? \"include\" : \"same-origin\",\r\n body: objBodyStr,\r\n headers: header,\r\n });\r\n const json = await res.json();\r\n\r\n let response = json;\r\n\r\n if (objTestingConfig.blnIsTestingMode) {\r\n console.log(\" \");\r\n console.log(objTestingConfig.strPageInfo + \"*------------------( routingPath\" + strRequester.routingPath + \" )----------------------------\");\r\n console.log(\"*\");\r\n console.log(response);\r\n console.log(\"*\");\r\n console.log(\"**********************************************************************************************************\");\r\n console.log(\" \");\r\n }\r\n\r\n return response;\r\n } catch (error) {\r\n if (objTestingConfig.blnIsTestingMode) {\r\n console.log(\" \");\r\n console.log(objTestingConfig.strPageInfo + \"*------------------( Error Fetch Data )----------------------------\");\r\n console.log(\"*\");\r\n console.error(error);\r\n console.log(\"*\");\r\n console.log(\"**********************************************************************************************************\");\r\n console.log(\" \");\r\n }\r\n\r\n if (objTestingConfig.blnIsTestingMode) {\r\n return error instanceof SyntaxError ? \"Server block the request.\" : error?.message ? error?.message : error;\r\n }\r\n }\r\n}\r\n//#endregion\r\n\r\n//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////\r\n\r\n//#region util functions\r\n\r\nfunction generatePatternID() {\r\n const element = [\r\n [\"q\", \"m\", \"p\", \"z\"],\r\n [\"u\", \"x\", \"c\", \"v\"],\r\n [\"W\", \"V\", \"Y\", \"N\", \"O\"],\r\n [\"$\", \"%\"],\r\n [\"2\", \"3\", \"9\", \"7\"],\r\n [\">\", \")\", \"!\"],\r\n [\"t\", \"u\", \"i\", \"o\", \"l\"],\r\n [\"f\", \"g\", \"y\", \"r\"],\r\n [\"H\", \"T\", \"B\", \"I\"],\r\n [\"#\", \"*\"],\r\n [\"0\", \"1\"],\r\n [\"K\", \"E\", \"T\", \"G\"],\r\n [\"b\", \"j\", \"o\", \"w\", \"a\"],\r\n [\"{\", \")\", \"@\"],\r\n [\"+\", \"_\", \"/\"],\r\n [\"6\", \"7\", \"2\", \"8\", \"1\"],\r\n [\"a\", \"h\", \"l\", \"<\", \";\"],\r\n [\"~\", \"3\", \"&\", \"m\", \"5\"],\r\n [\"|\", \"*\", \"2\", \"v\", \"9\", \"s\"],\r\n [\"%\", \"1\", \"8\", \"t\", \"q\", \"z\", \"7\", \"@\", \"-\"],\r\n ];\r\n\r\n let result = \"\";\r\n\r\n for (let i = 0; i < element.length; i++) {\r\n result += element[i][Math.floor(Math.random() * element[i].length)];\r\n }\r\n\r\n return result;\r\n}\r\n\r\nfunction setAppLocalStorage(appStateObject, strLocalStorageName, blnIsEncrypted = false, strEncryptKey = \"secret\") {\r\n let plainTextLocalStorage = JSON.stringify(appStateObject);\r\n\r\n if (blnIsEncrypted) {\r\n let cipherTextLocalStorage = encryptText(plainTextLocalStorage, strEncryptKey);\r\n localStorage.setItem(strLocalStorageName, cipherTextLocalStorage);\r\n } else {\r\n localStorage.setItem(strLocalStorageName, plainTextLocalStorage);\r\n }\r\n}\r\n\r\nfunction getAppLocalStorage(strLocalStorageName, blnIsEncrypted = false, strEncryptKey = \"secret\") {\r\n try {\r\n let txtLocalStorage = localStorage.getItem(strLocalStorageName);\r\n\r\n if (blnIsEncrypted) {\r\n let plainTextLocalStorage = decryptText(txtLocalStorage, strEncryptKey);\r\n return appFunctions.checkParseObject(plainTextLocalStorage);\r\n } else {\r\n return appFunctions.checkParseObject(txtLocalStorage);\r\n }\r\n } catch (e) {\r\n return {};\r\n }\r\n}\r\n\r\nfunction encryptText(strPlaintText, strKeyOfEncrypt) {\r\n // Encrypt\r\n let cipherText = String(CryptoJS.AES.encrypt(strPlaintText, strKeyOfEncrypt));\r\n return cipherText;\r\n}\r\n\r\nfunction decryptText(strCipherText, strKeyOfDecrypt) {\r\n //Decrypt\r\n let bytes = CryptoJS.AES.decrypt(strCipherText, strKeyOfDecrypt);\r\n let plaintText = bytes.toString(CryptoJS.enc.Utf8);\r\n\r\n return plaintText;\r\n}\r\n\r\nfunction encryptTextRabbit(strPlaintText, strKeyOfEncrypt) {\r\n // Encrypt\r\n let cipherText = String(CryptoJS.Rabbit.encrypt(strPlaintText, strKeyOfEncrypt));\r\n return cipherText;\r\n}\r\n\r\nfunction decryptTextRabbit(strCipherText, strKeyOfDecrypt) {\r\n //Decrypt\r\n let bytes = CryptoJS.Rabbit.decrypt(strCipherText, strKeyOfDecrypt);\r\n let plaintText = bytes.toString(CryptoJS.enc.Utf8);\r\n\r\n return plaintText;\r\n}\r\n\r\nfunction getDifferenceBetweenTwoDate(dtmOldestDate, dtmNewestDate, strIntervalReturnValue) {\r\n try {\r\n const intTime2 = new Date(dtmNewestDate).getTime();\r\n const intTime1 = new Date(dtmOldestDate).getTime();\r\n const diffTime = intTime2 - intTime1;\r\n\r\n switch (strIntervalReturnValue) {\r\n case \"second\":\r\n return diffTime / 1000;\r\n case \"minute\":\r\n return diffTime / 1000 / 60;\r\n case \"hour\":\r\n return diffTime / 1000 / 60 / 60;\r\n case \"day\":\r\n return diffTime / 1000 / 60 / 60 / 24;\r\n case \"month\":\r\n return diffTime / 1000 / 60 / 60 / 24 / 30.4375;\r\n case \"year\":\r\n return diffTime / 1000 / 60 / 60 / 24 / 30.4375 / 12;\r\n default:\r\n return Number.NaN;\r\n }\r\n } catch (error) {\r\n return Number.NaN;\r\n }\r\n}\r\n\r\nfunction generateRandomStringSecure(length) {\r\n const characters = \"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789\";\r\n const charactersLength = characters.length;\r\n let result = \"\";\r\n\r\n // Create an array of 32-bit unsigned integers\r\n const randomValues = new Uint32Array(length);\r\n\r\n // Generate random values\r\n window.crypto.getRandomValues(randomValues);\r\n randomValues.forEach((value) => {\r\n result += characters.charAt(value % charactersLength);\r\n });\r\n return result;\r\n}\r\n//#endregion","/** \r\n* @param {string} dir\r\n*/\r\nexport const App_Direction_LeftToRight = \"ltr\";\r\nexport const App_Direction_RightToLeft = \"rtl\";\r\n\r\nexport const setDirection = (dir)=>{\r\n document.body.setAttribute('dir', 'ltr')\r\n document.body.style.direction= \"ltr\";\r\n if(String(dir).toLowerCase() === \"rtl\"){\r\n // document.body.classList.add(`cbmis-body-dir-rtl`);\r\n document.body.setAttribute('dir', 'rtl')\r\n document.body.style.direction= \"rtl\";\r\n }\r\n}\r\n\r\nexport function setDirectionByLanguage(strLanguage) {\r\n const lang = String(strLanguage).toLowerCase();\r\n if (lang === \"ar\" || lang === \"arb\" || lang === \"arabic\") \r\n setDirection(App_Direction_RightToLeft);\r\n else\r\n setDirection(App_Direction_LeftToRight);\r\n }","\r\n// self.addEventListener(\"push\", function (event) {\r\n// try {\r\n// const data = event.data.json();\r\n// self.registration.showNotification(data.title, { ...data?.option });\r\n// } catch (error) {\r\n// console.log(error);\r\n// }\r\n// });\r\n\r\n /**\r\n *\r\n * @param {string} title\r\n * @param {NotificationOptions} option\r\n * @param {boolean} isTest\r\n */\r\n export function offlineNotification(title, option, isTest = true) {\r\n if (!(\"Notification\" in window && navigator.serviceWorker)) {\r\n if (isTest) {\r\n console.warn(\"This browser does not support desktop notification\");\r\n }\r\n } else if (Notification.permission === \"granted\") {\r\n new Notification(title, option);\r\n } else if (Notification.permission !== \"denied\") {\r\n Notification.requestPermission().then(function (permission) {\r\n if (permission === \"granted\") {\r\n new Notification(title, option);\r\n }\r\n });\r\n }\r\n }\r\n\r\n /**\r\n *\r\n * @param {string} strSubscribeLink\r\n * @param {string} strGetPublicKeyLink\r\n * @param {string} strServerWorkerPath\r\n * @param {boolean} isTest\r\n */\r\n export async function pushNotification(strSubscribeLink, strGetPublicKeyLink, strServerWorkerPath = \"/worker.js\", isTest = true) {\r\n try {\r\n function urlBase64ToUint8Array(base64String) {\r\n const padding = \"=\".repeat((4 - (base64String.length % 4)) % 4);\r\n const base64 = (base64String + padding).replace(/\\-/g, \"+\").replace(/_/g, \"/\");\r\n\r\n const rawData = window.atob(base64);\r\n const outputArray = new Uint8Array(rawData.length);\r\n\r\n for (let i = 0; i < rawData.length; ++i) {\r\n outputArray[i] = rawData.charCodeAt(i);\r\n }\r\n return outputArray;\r\n }\r\n\r\n if (!(\"serviceWorker\" in navigator)) {\r\n if (isTest) {\r\n console.warn(\"Service worker not supported.\");\r\n }\r\n return;\r\n }\r\n\r\n await navigator.serviceWorker.register(strServerWorkerPath, {\r\n scope: \"/\",\r\n });\r\n\r\n const serviceWorkerReady = await navigator.serviceWorker.ready;\r\n\r\n const prevSubscribe = await serviceWorkerReady.pushManager.getSubscription();\r\n\r\n if (prevSubscribe) {\r\n const res = await fetch(strSubscribeLink, {\r\n method: \"POST\",\r\n body: JSON.stringify(prevSubscribe),\r\n headers: {\r\n \"Content-Type\": \"application/json\",\r\n },\r\n });\r\n\r\n if (res.status >= 400) {\r\n await unregisterServiceWorker();\r\n }\r\n return;\r\n }\r\n\r\n const publicVapidIDResponse = await fetch(strGetPublicKeyLink, {\r\n method: \"GET\",\r\n });\r\n\r\n const publicVapidID = await publicVapidIDResponse.json();\r\n\r\n const subscription = await serviceWorkerReady.pushManager.subscribe({\r\n userVisibleOnly: true,\r\n applicationServerKey: urlBase64ToUint8Array(publicVapidID.publicKey),\r\n });\r\n\r\n const res = await fetch(strSubscribeLink, {\r\n method: \"POST\",\r\n body: JSON.stringify(subscription),\r\n headers: {\r\n \"Content-Type\": \"application/json\",\r\n },\r\n });\r\n\r\n if (res.status >= 400) {\r\n await unregisterServiceWorker();\r\n }\r\n } catch (error) {\r\n if (isTest) {\r\n console.error(error);\r\n }\r\n }\r\n }\r\n\r\n export async function unregisterServiceWorker(isTest = false) {\r\n try {\r\n if (!(\"serviceWorker\" in navigator)) {\r\n return;\r\n }\r\n const serviceWorkerReady = await navigator.serviceWorker.ready;\r\n serviceWorkerReady.unregister();\r\n //window.location.reload();\r\n } catch (error) {\r\n if (isTest) {\r\n console.error(error);\r\n }\r\n }\r\n }\r\n \r\n\r\n\r\n\r\n /**\r\n *\r\n * @param {string} strSubscribeLink\r\n * @param {string} strGetPublicKeyLink\r\n * @param {string} strServerWorkerPath\r\n * @param {boolean} isTest\r\n */\r\n export async function pushNotificationForMe(strSubscribeLink, strGetPublicKeyLink, strServerWorkerPath = \"./serviceWorker.js\", isTest = true) {\r\n try {\r\n function urlBase64ToUint8Array(base64String) {\r\n const padding = \"=\".repeat((4 - (base64String.length % 4)) % 4);\r\n const base64 = (base64String + padding).replace(/\\-/g, \"+\").replace(/_/g, \"/\");\r\n \r\n const rawData = window.atob(base64);\r\n const outputArray = new Uint8Array(rawData.length);\r\n \r\n for (let i = 0; i < rawData.length; ++i) {\r\n outputArray[i] = rawData.charCodeAt(i);\r\n }\r\n return outputArray;\r\n }\r\n \r\n if (!(\"serviceWorker\" in navigator)) {\r\n if (isTest) {\r\n console.warn(\"Service worker not supported.\");\r\n }\r\n return;\r\n }\r\n \r\n if (!(\"PushManager\" in window)) {\r\n if (isTest) {\r\n console.warn(\"Push isn't supported on this browser.\");\r\n }\r\n return;\r\n }\r\n \r\n if (!(\"Notification\" in window && navigator.serviceWorker)) {\r\n if (isTest) {\r\n console.warn(\"This browser does not support desktop notification\");\r\n }\r\n return;\r\n }\r\n \r\n if (Notification.permission === \"denied\") {\r\n if (isTest) {\r\n console.warn(\"Notification permission is denied by the user.\");\r\n }\r\n return;\r\n }\r\n \r\n await navigator.serviceWorker.register(strServerWorkerPath, {\r\n scope: \"/\",\r\n });\r\n \r\n const serviceWorkerReady = await navigator.serviceWorker.ready;\r\n \r\n const prevSubscribe = await serviceWorkerReady.pushManager.getSubscription();\r\n \r\n if (prevSubscribe) {\r\n const res = await fetch(strSubscribeLink, {\r\n method: \"POST\",\r\n body: JSON.stringify(prevSubscribe),\r\n headers: {\r\n \"Content-Type\": \"application/json\",\r\n },\r\n });\r\n \r\n if (res.status >= 400) {\r\n await unregisterServiceWorker();\r\n }\r\n return;\r\n }\r\n \r\n const publicVapidIDResponse = await fetch(strGetPublicKeyLink, {\r\n method: \"GET\",\r\n });\r\n \r\n const publicVapidID = await publicVapidIDResponse.json();\r\n \r\n const subscription = await serviceWorkerReady.pushManager.subscribe({\r\n userVisibleOnly: true,\r\n applicationServerKey: urlBase64ToUint8Array(publicVapidID.publicKey),\r\n });\r\n \r\n const res = await fetch(strSubscribeLink, {\r\n method: \"POST\",\r\n body: JSON.stringify(subscription),\r\n headers: {\r\n \"Content-Type\": \"application/json\",\r\n },\r\n });\r\n \r\n if (res.status >= 400) {\r\n await unregisterServiceWorker();\r\n }\r\n } catch (error) {\r\n if (isTest) {\r\n console.error(error);\r\n }\r\n }\r\n }\r\n\r\n\r\n \r\n\r\n/**\r\n *\r\n * @param {string} strSetSubscriptionLink\r\n * @param {string} strGetPublicKeyLink\r\n * @param {string} strServerWorkerPath\r\n * @param {boolean} isTest\r\n */\r\nexport async function registerPushServiceWorker(strSetSubscriptionLink, strGetPublicKeyLink, strServerWorkerPath = \"./serviceWorker.js\", isTest = false) {\r\n try {\r\n function urlBase64ToUint8Array(base64String) {\r\n const padding = \"=\".repeat((4 - (base64String.length % 4)) % 4);\r\n const base64 = (base64String + padding).replace(/\\-/g, \"+\").replace(/_/g, \"/\");\r\n\r\n const rawData = window.atob(base64);\r\n const outputArray = new Uint8Array(rawData.length);\r\n\r\n for (let i = 0; i < rawData.length; ++i) {\r\n outputArray[i] = rawData.charCodeAt(i);\r\n }\r\n return outputArray;\r\n }\r\n\r\n if (!(\"serviceWorker\" in navigator)) {\r\n if (isTest) {\r\n console.warn(\"Service worker not supported.\");\r\n }\r\n return;\r\n }\r\n\r\n if (!(\"PushManager\" in window)) {\r\n if (isTest) {\r\n console.warn(\"Push isn't supported on this browser.\");\r\n }\r\n return;\r\n }\r\n\r\n if (!(\"Notification\" in window && navigator.serviceWorker)) {\r\n if (isTest) {\r\n console.warn(\"This browser does not support desktop notification\");\r\n }\r\n return;\r\n }\r\n\r\n if (Notification.permission === \"denied\") {\r\n if (isTest) {\r\n console.warn(\"Notification permission is denied by the user.\");\r\n }\r\n return;\r\n }\r\n\r\n await navigator.serviceWorker.register(strServerWorkerPath, {\r\n scope: \"/\",\r\n });\r\n\r\n const serviceWorkerReady = await navigator.serviceWorker.ready;\r\n\r\n let activeSubscription;\r\n const prevSubscribe = await serviceWorkerReady.pushManager.getSubscription();\r\n activeSubscription = prevSubscribe;\r\n if (!prevSubscribe) {\r\n const publicVapidIDResponse = await fetch(strGetPublicKeyLink, {\r\n method: \"GET\",\r\n });\r\n\r\n const publicVapidID = await publicVapidIDResponse.json();\r\n\r\n const subscription = await serviceWorkerReady.pushManager.subscribe({\r\n userVisibleOnly: true,\r\n applicationServerKey: urlBase64ToUint8Array(publicVapidID.publicKey),\r\n });\r\n activeSubscription = subscription;\r\n }\r\n\r\n await fetch(strSetSubscriptionLink, {\r\n method: \"POST\",\r\n body: JSON.stringify(activeSubscription),\r\n headers: {\r\n \"Content-Type\": \"application/json\",\r\n },\r\n });\r\n } catch (error) {\r\n if (isTest) {\r\n console.error(error);\r\n }\r\n }\r\n}\r\n\r\n","import React, { createContext, useContext, useEffect, useReducer, useState } from \"react\";\r\nimport * as ClientFunction from \"../system/cbmisFunction\";\r\n\r\n// /**\r\n// * @param {any} appInitialState\r\n// * @param {React.Context} AppContext\r\n// * @param {string} strAppLocalStorageName\r\n// * @param {boolean} blnIsEncrypt\r\n// * @param {string} strEncryptKey\r\n// * @param {boolean} blnIsTestingMode\r\n// * @returns {(props: any) => JSX.Element}\r\n// */\r\nexport const capitalize = (str) => {\r\n return String(str).charAt(0).toUpperCase() + String(str).slice(1);\r\n};\r\nexport const funAppContext = () => {\r\n return createContext({ state: {}, dispatch: (newState) => null });\r\n};\r\n\r\nexport const ContextLayerProvider = React.createContext({});\r\n\r\nexport function funAppProvider(appInitialState, AppContext, contextName, strAppVersion, strAppLocalStorageName = undefined, blnIsEncrypt = false, strEncryptKey = \"secret\", blnIsTestingMode = true) {\r\n const UPDATE_APP_STATE = \"UPDATE_APP_STATE\";\r\n const UPDATE_All_APP_STATE = \"UPDATE_All_APP_STATE\";\r\n\r\n function AppReducer(state, action) {\r\n switch (action?.type) {\r\n case UPDATE_APP_STATE:\r\n if (strAppLocalStorageName) {\r\n ClientFunction.setAppLocalStorage({ ...state, ...action.newAppState }, strAppLocalStorageName, blnIsEncrypt, strEncryptKey);\r\n }\r\n return { ...state, ...action.newAppState };\r\n case UPDATE_All_APP_STATE:\r\n if (strAppLocalStorageName) {\r\n ClientFunction.setAppLocalStorage({ ...action.newAppState }, strAppLocalStorageName, blnIsEncrypt, strEncryptKey);\r\n }\r\n return { ...action.newAppState };\r\n default:\r\n if (strAppLocalStorageName) {\r\n ClientFunction.setAppLocalStorage({ ...state }, strAppLocalStorageName, blnIsEncrypt, strEncryptKey);\r\n }\r\n return { ...state };\r\n }\r\n }\r\n\r\n function AppProviderImpl(props) {\r\n const [appState, appDispatch] = useReducer(AppReducer, appInitialState);\r\n const [isLoading, setIsLoading] = useState(true);\r\n\r\n useEffect(() => {\r\n if (strAppLocalStorageName) {\r\n try {\r\n if (localStorage.hasOwnProperty(strAppLocalStorageName) && localStorage.getItem(strAppLocalStorageName) !== null) {\r\n const localState = ClientFunction.getAppLocalStorage(strAppLocalStorageName, blnIsEncrypt, strEncryptKey);\r\n if (localState?.clientInfo?.strAppVersion !== strAppVersion) {\r\n appDispatch({ type: UPDATE_APP_STATE, newAppState: appState });\r\n } else {\r\n appDispatch({ type: UPDATE_APP_STATE, newAppState: localState });\r\n }\r\n if (blnIsTestingMode) {\r\n console.log(`[${new Date().toLocaleTimeString(\"sv-SE\")}] appState-localStorage updated ✅`);\r\n }\r\n }\r\n setIsLoading(false);\r\n } catch (error) {\r\n if (blnIsTestingMode) {\r\n console.log(`[${new Date().toLocaleTimeString(\"sv-SE\")}] appState-localStorage can't update 💥`, error);\r\n }\r\n setIsLoading(false);\r\n }\r\n } else {\r\n setIsLoading(false);\r\n }\r\n }, []);\r\n\r\n return (\r\n \r\n {isLoading ? null : props.children}\r\n \r\n );\r\n }\r\n\r\n function AppContextImpl() {\r\n const { state, dispatch } = useContext(AppContext);\r\n\r\n const appContext = (newState = null) => {\r\n try {\r\n if (newState) {\r\n dispatch({ type: UPDATE_All_APP_STATE, newAppState: newState });\r\n } else {\r\n dispatch();\r\n }\r\n } catch (error) {\r\n console.error(error);\r\n return state;\r\n }\r\n };\r\n return {\r\n [`${String(contextName).toLowerCase()}State`]: state,\r\n [`${String(contextName).toLowerCase()}Dispatch`]: appContext,\r\n };\r\n }\r\n\r\n return {\r\n AppProvider: AppProviderImpl,\r\n appContext: AppContextImpl,\r\n };\r\n}\r\n","\r\nimport { capitalize, funAppContext, funAppProvider } from './AppProviderHelper'\r\nimport searchFile from './searchState';\r\n\r\n// console.log(searchFile(\"./src\"));\r\n\r\nexport default function ContextProvider(appInitialState,contextName=\"app\",strAppVersion=\"v1\", strAppLocalStorageName = \"appLocalStorageName\", blnIsEncrypt = false, strEncryptKey = \"secret\", blnIsTestingMode = true) {\r\n const AppContext = funAppContext();\r\n if(appInitialState?.clientInfo?.strAppVersion){\r\n appInitialState.clientInfo.strAppVersion = strAppVersion\r\n }\r\n const {AppProvider, appContext} = funAppProvider(\r\n appInitialState,\r\n AppContext,\r\n contextName,\r\n strAppVersion,\r\n strAppLocalStorageName,\r\n blnIsEncrypt,\r\n strEncryptKey,\r\n blnIsTestingMode,\r\n );\r\n\r\n return{\r\n [`${capitalize(contextName)}Context`]:AppContext,\r\n [`${capitalize(contextName)}Provider`]:AppProvider,\r\n [`use${capitalize(contextName)}`]:appContext\r\n }\r\n}","import React, { useEffect, useReducer, useState } from 'react'\r\nimport * as ClientFunction from '../system/cbmisFunction';\r\n\r\n/**\r\n *\r\n * @param {any} appInitialState \r\n * @param {React.Context} AppContext \r\n * @param {string} strAppLocalStorageName \r\n * @param {boolean} blnIsEncrypt \r\n * @param {string} strEncryptKey \r\n * @param {boolean} blnIsTestingMode \r\n * @returns {(props: any) => JSX.Element}\r\n */\r\n\r\nfunction AppProvider(appInitialState, AppContext, strAppVersion=\"\" ,strAppLocalStorageName = undefined, blnIsEncrypt = false, strEncryptKey = \"secret\", blnIsTestingMode = true) {\r\n const UPDATE_APP_STATE = \"UPDATE_APP_STATE\";\r\n function AppReducer(state, action) {\r\n switch (action?.type) {\r\n case UPDATE_APP_STATE:\r\n if (strAppLocalStorageName) {\r\n ClientFunction.setAppLocalStorage({ ...state, ...action.newAppState }, strAppLocalStorageName, blnIsEncrypt, strEncryptKey);\r\n }\r\n return { ...state, ...action.newAppState };\r\n\r\n default:\r\n if (strAppLocalStorageName) {\r\n ClientFunction.setAppLocalStorage({ ...state }, strAppLocalStorageName, blnIsEncrypt, strEncryptKey);\r\n }\r\n return { ...state };\r\n }\r\n }\r\n\r\n return function AppProviderImpl(props) {\r\n const [appState, appDispatch] = useReducer(AppReducer, appInitialState);\r\n const [isLoading, setIsLoading] = useState(true);\r\n\r\n useEffect(() => {\r\n if (strAppLocalStorageName) {\r\n try {\r\n if (localStorage.hasOwnProperty(strAppLocalStorageName) && localStorage.getItem(strAppLocalStorageName) !== null) {\r\n const localState = ClientFunction.getAppLocalStorage(strAppLocalStorageName, blnIsEncrypt, strEncryptKey)\r\n if(localState?.clientInfo?.strAppVersion !== strAppVersion){\r\n // @ts-ignore\r\n appDispatch({ type: UPDATE_APP_STATE, newAppState: appState });\r\n }else{\r\n // @ts-ignore\r\n appDispatch({ type: UPDATE_APP_STATE, newAppState: localState });\r\n }\r\n if (blnIsTestingMode) {\r\n console.log(`[${new Date().toLocaleTimeString(\"sv-SE\")}] appState-localStorage updated ✅`);\r\n }\r\n }\r\n setIsLoading(false);\r\n } catch (error) {\r\n if (blnIsTestingMode) {\r\n console.log(`[${new Date().toLocaleTimeString(\"sv-SE\")}] appState-localStorage can't update 💥`, error);\r\n }\r\n setIsLoading(false);\r\n }\r\n } else {\r\n setIsLoading(false);\r\n }\r\n }, []);\r\n\r\n return (\r\n \r\n {isLoading ? null : props.children}\r\n \r\n );\r\n };\r\n}\r\n\r\nexport default AppProvider","var __WEBPACK_NAMESPACE_OBJECT__ = require(\"qrcode\");","import React, { useEffect, useState } from \"react\";\r\nimport QRCode from \"qrcode\";\r\n// import {styleFunction} from \"@cbmisorg/styles\"\r\n\r\nexport default function QRCodeGenerator({ strText , background= \"light\", color=\"dark\", size=3}) {\r\n const [state, setState] = useState({ qrCodeImg: \"\" });\r\n useEffect(() => {\r\n generateQRCode();\r\n }, [strText]);\r\n\r\n async function generateQRCode() {\r\n try {\r\n const qrResult = await QRCode.toDataURL(strText, { errorCorrectionLevel: \"H\", color: { dark: color, light:background }, type: \"image/png\", scale: size});\r\n state.qrCodeImg = qrResult;\r\n setState({ ...state });\r\n return;\r\n } catch (error) {\r\n console.log(error);\r\n }\r\n }\r\n\r\n return ;\r\n}\r\n","\"use client\";\r\nimport { useEffect, useState } from \"react\";\r\n\r\nexport default function useScreenSize() {\r\n\r\n function getSize() {\r\n const isClient = typeof window !== \"undefined\";\r\n\r\n return {\r\n width: isClient ? window.innerWidth : undefined,\r\n height: isClient ? window.innerHeight : undefined,\r\n };\r\n }\r\n\r\n const [windowSize, setWindowSize] = useState({width:window?.innerWidth || undefined, height:window?.innerHeight || undefined});\r\n\r\n useEffect(() => {\r\n function handleResize() {\r\n setWindowSize(getSize());\r\n }\r\n\r\n window.addEventListener(\"resize\", handleResize);\r\n\r\n return () => {\r\n window.removeEventListener(\"resize\", handleResize);\r\n };\r\n }, []);\r\n\r\n return windowSize;\r\n}\r\n","var getProto = Object.getPrototypeOf ? function(obj) { return Object.getPrototypeOf(obj); } : function(obj) { return obj.__proto__; };\nvar leafPrototypes;\n// create a fake namespace object\n// mode & 1: value is a module id, require it\n// mode & 2: merge all properties of value into the ns\n// mode & 4: return value when already ns object\n// mode & 16: return value when it's Promise-like\n// mode & 8|1: behave like require\n__webpack_require__.t = function(value, mode) {\n\tif(mode & 1) value = this(value);\n\tif(mode & 8) return value;\n\tif(typeof value === 'object' && value) {\n\t\tif((mode & 4) && value.__esModule) return value;\n\t\tif((mode & 16) && typeof value.then === 'function') return value;\n\t}\n\tvar ns = Object.create(null);\n\t__webpack_require__.r(ns);\n\tvar def = {};\n\tleafPrototypes = leafPrototypes || [null, getProto({}), getProto([]), getProto(getProto)];\n\tfor(var current = mode & 2 && value; typeof current == 'object' && !~leafPrototypes.indexOf(current); current = getProto(current)) {\n\t\tObject.getOwnPropertyNames(current).forEach(function(key) { def[key] = function() { return value[key]; }; });\n\t}\n\tdef['default'] = function() { return value; };\n\t__webpack_require__.d(ns, def);\n\treturn ns;\n};","var map = {\n\t\"./aabychangingstation.json\": 16169,\n\t\"./abc.json\": 82001,\n\t\"./accessibilitynew.json\": 34821,\n\t\"./accessible.json\": 99165,\n\t\"./accessibleforward.json\": 2106,\n\t\"./accesstime.json\": 53680,\n\t\"./accesstimefilled.json\": 19328,\n\t\"./accountbalance.json\": 4566,\n\t\"./accountbalanceoutlined.json\": 14240,\n\t\"./accountbalancewallet.json\": 58515,\n\t\"./accountbalancewalletoutlined.json\": 29285,\n\t\"./accountbox.json\": 4107,\n\t\"./accountboxoutlined.json\": 17085,\n\t\"./accountcircle.json\": 90674,\n\t\"./accountcircleoutlined.json\": 98548,\n\t\"./accounttree.json\": 31134,\n\t\"./accounttreeoutlined.json\": 84872,\n\t\"./acnitu.json\": 52493,\n\t\"./adb.json\": 86868,\n\t\"./add.json\": 89482,\n\t\"./addalarm.json\": 90299,\n\t\"./addalert.json\": 76340,\n\t\"./addalertoutlined.json\": 89686,\n\t\"./addbox.json\": 76539,\n\t\"./addboxoutlined.json\": 301,\n\t\"./addbusiness.json\": 15036,\n\t\"./addbusinessoutlined.json\": 76510,\n\t\"./addchart.json\": 47126,\n\t\"./addcircle.json\": 1634,\n\t\"./addcircleoutlined.json\": 1348,\n\t\"./addcomment.json\": 55547,\n\t\"./addcommentoutlined.json\": 52461,\n\t\"./addiccall.json\": 68914,\n\t\"./addiccalloutlined.json\": 24308,\n\t\"./addlink.json\": 30242,\n\t\"./addlocation.json\": 55497,\n\t\"./addlocationalt.json\": 70263,\n\t\"./addlocationaltoutlined.json\": 51110,\n\t\"./addlocationoutlined.json\": 45579,\n\t\"./addmoderator.json\": 84313,\n\t\"./addmoderatoroutlined.json\": 59867,\n\t\"./addphoto.json\": 73138,\n\t\"./addphotoalternate.json\": 62408,\n\t\"./addphotoalternateoutlined.json\": 9426,\n\t\"./addphotooutlined.json\": 41268,\n\t\"./addreaction.json\": 21477,\n\t\"./addreactionoutlined.json\": 3071,\n\t\"./addroad.json\": 45556,\n\t\"./addshoppingcart.json\": 94992,\n\t\"./addtask.json\": 56779,\n\t\"./addtodrive.json\": 64525,\n\t\"./addtodriveoutlined.json\": 77716,\n\t\"./addtohomescreen.json\": 91052,\n\t\"./addtophotos.json\": 40134,\n\t\"./addtophotosoutlined.json\": 75056,\n\t\"./addtoqueue.json\": 85934,\n\t\"./adjust.json\": 16604,\n\t\"./adminmeds.json\": 99001,\n\t\"./adminpanelsettings.json\": 13041,\n\t\"./adminpanelsettingsoutlined.json\": 91731,\n\t\"./adunits.json\": 23877,\n\t\"./adunitsoutlined.json\": 76223,\n\t\"./agriculture.json\": 73492,\n\t\"./agricultureoutlined.json\": 92662,\n\t\"./air.json\": 74913,\n\t\"./airlineeeatflat.json\": 55891,\n\t\"./airlineseatflatangled.json\": 33864,\n\t\"./airlineseatflatangledoutlined.json\": 17554,\n\t\"./airlineseatflatoutlined.json\": 67364,\n\t\"./airlineseatindividualsuite.json\": 6979,\n\t\"./airlineseatindividualsuiteoutlined.json\": 58197,\n\t\"./airlineseatlegroomextra.json\": 83769,\n\t\"./airlineseatlegroomnormal.json\": 33394,\n\t\"./airlineseatlegroomreduced.json\": 7305,\n\t\"./airlineseatreclineextra.json\": 51328,\n\t\"./airlineseatreclinenormal.json\": 21117,\n\t\"./airlineseatreclinenormaloutlined.json\": 71255,\n\t\"./airoutlined.json\": 72355,\n\t\"./airplanemodeactive.json\": 90420,\n\t\"./airplanemodeinactive.json\": 36655,\n\t\"./airplaneticket.json\": 16697,\n\t\"./airplaneticketoutlined.json\": 22139,\n\t\"./airplay.json\": 27115,\n\t\"./airportshuttle.json\": 91115,\n\t\"./airportshuttleoutlined.json\": 84445,\n\t\"./alarm.json\": 65624,\n\t\"./alarmadd.json\": 25731,\n\t\"./alarmoff.json\": 25657,\n\t\"./alarmon.json\": 83365,\n\t\"./album.json\": 99102,\n\t\"./albumoutlined.json\": 13736,\n\t\"./alignhorizontalcenter.json\": 64749,\n\t\"./alignhorizontalcenteroutlined.json\": 75431,\n\t\"./alignhorizontalleft.json\": 41061,\n\t\"./alignhorizontalright.json\": 61198,\n\t\"./alignverticalbottom.json\": 94125,\n\t\"./alignverticalcenter.json\": 33311,\n\t\"./alignverticaltop.json\": 67305,\n\t\"./allinbox.json\": 29202,\n\t\"./allinboxoutlined.json\": 62548,\n\t\"./allinclusive.json\": 92644,\n\t\"./allout.json\": 2230,\n\t\"./alternateemail.json\": 2905,\n\t\"./altroute.json\": 35695,\n\t\"./analytics.json\": 93029,\n\t\"./analyticsoutlined.json\": 20159,\n\t\"./anchor.json\": 69374,\n\t\"./android.json\": 58198,\n\t\"./animation.json\": 23787,\n\t\"./announcement.json\": 66752,\n\t\"./announcementoutlined.json\": 29066,\n\t\"./aod.json\": 67569,\n\t\"./aodoutlined.json\": 52531,\n\t\"./apartment.json\": 86771,\n\t\"./api.json\": 30749,\n\t\"./appblocking.json\": 617,\n\t\"./appblockingoutlined.json\": 73387,\n\t\"./apple.json\": 71229,\n\t\"./appregistration.json\": 83583,\n\t\"./approval.json\": 44832,\n\t\"./apps.json\": 45159,\n\t\"./appsettingsalt.json\": 10530,\n\t\"./appsettingsaltoutlined.json\": 49508,\n\t\"./architecture.json\": 53944,\n\t\"./arrowback.json\": 28171,\n\t\"./arrowbackios.json\": 97048,\n\t\"./arrowbackiosnew.json\": 92962,\n\t\"./arrowcircledown.json\": 69312,\n\t\"./arrowcircledownoutlined.json\": 5002,\n\t\"./arrowcircleup.json\": 79781,\n\t\"./arrowcircleupoutlined.json\": 72287,\n\t\"./arrowdownward.json\": 36866,\n\t\"./arrowdropdown.json\": 26569,\n\t\"./arrowdropdowncircle.json\": 98933,\n\t\"./arrowdropdowncircleoutlined.json\": 30575,\n\t\"./arrowdropup.json\": 93984,\n\t\"./arrowforward.json\": 81345,\n\t\"./arrowforwardios.json\": 45410,\n\t\"./arrowleft.json\": 52821,\n\t\"./arrowright.json\": 77918,\n\t\"./arrowupward.json\": 15843,\n\t\"./article.json\": 34211,\n\t\"./articleoutlined.json\": 69557,\n\t\"./arttrack.json\": 98087,\n\t\"./assessment.json\": 28669,\n\t\"./assessmentoutlined.json\": 68119,\n\t\"./assignment.json\": 27950,\n\t\"./assignmentind.json\": 84219,\n\t\"./assignmentindoutlined.json\": 29101,\n\t\"./assignmentlate.json\": 30669,\n\t\"./assignmentlateoutlined.json\": 7228,\n\t\"./assignmentoutlined.json\": 37944,\n\t\"./assignmentreturn.json\": 71436,\n\t\"./assignmentreturned.json\": 29249,\n\t\"./assignmentreturnedoutlined.json\": 25891,\n\t\"./assignmentreturnoutlined.json\": 70126,\n\t\"./assignmentturnedin.json\": 88455,\n\t\"./assignmentturnedinoutlined.json\": 9121,\n\t\"./assistant.json\": 20661,\n\t\"./assistantdirection.json\": 66802,\n\t\"./assistantdirectionoutlined.json\": 22676,\n\t\"./assistantoutlined.json\": 28015,\n\t\"./assistantphoto.json\": 21207,\n\t\"./assistantphotooutlined.json\": 8881,\n\t\"./atm.json\": 81581,\n\t\"./attachemail.json\": 56622,\n\t\"./attachemailoutlined.json\": 20568,\n\t\"./attachfile.json\": 80208,\n\t\"./attachment.json\": 5130,\n\t\"./attachmoney.json\": 66034,\n\t\"./attractions.json\": 86415,\n\t\"./attribution.json\": 99536,\n\t\"./audiotrack.json\": 61866,\n\t\"./audiotrackoutlined.json\": 63596,\n\t\"./autoawesome.json\": 55759,\n\t\"./autoawesomemosaic.json\": 92671,\n\t\"./autoawesomemosaicoutlined.json\": 45593,\n\t\"./autoawesomemotion.json\": 85009,\n\t\"./autoawesomemotionoutlined.json\": 10579,\n\t\"./autoawesomeoutlined.json\": 93481,\n\t\"./autodelete.json\": 34171,\n\t\"./autodeleteoutlined.json\": 59597,\n\t\"./autofixhigh.json\": 5575,\n\t\"./autofixhighoutlined.json\": 99425,\n\t\"./autofixnormal.json\": 70956,\n\t\"./autofixnormaloutlined.json\": 27054,\n\t\"./autofixoff.json\": 42120,\n\t\"./autofixoffoutlined.json\": 42962,\n\t\"./autofpsselect.json\": 40999,\n\t\"./autograph.json\": 67244,\n\t\"./autorenew.json\": 92089,\n\t\"./autostories.json\": 26541,\n\t\"./autostoriesoutlined.json\": 97383,\n\t\"./avtimer.json\": 4029,\n\t\"./backpack.json\": 8505,\n\t\"./backpackoutlined.json\": 38363,\n\t\"./backspace.json\": 82678,\n\t\"./backspaceoutlined.json\": 47712,\n\t\"./backup.json\": 80333,\n\t\"./backupoutlined.json\": 19431,\n\t\"./backuptable.json\": 83347,\n\t\"./badge.json\": 11590,\n\t\"./badgeoutlined.json\": 19984,\n\t\"./bakerydining.json\": 2322,\n\t\"./bakerydiningoutlined.json\": 67348,\n\t\"./balcony.json\": 31365,\n\t\"./ballot.json\": 25913,\n\t\"./ballotoutlined.json\": 15035,\n\t\"./barchart.json\": 66660,\n\t\"./basket.json\": 86393,\n\t\"./beachaccess.json\": 10036,\n\t\"./beachaccessoutlined.json\": 37686,\n\t\"./bed.json\": 98078,\n\t\"./bedroombaby.json\": 8065,\n\t\"./bedroombabyoutlined.json\": 69411,\n\t\"./bedroomchild.json\": 98669,\n\t\"./bedroomchildoutlined.json\": 37895,\n\t\"./bedroomparent.json\": 65341,\n\t\"./bedroomparentoutlined.json\": 64983,\n\t\"./bedtime.json\": 12371,\n\t\"./bedtimeoutlined.json\": 14629,\n\t\"./beenhere.json\": 72103,\n\t\"./beenhereoutlined.json\": 68225,\n\t\"./bento.json\": 42801,\n\t\"./bentooutlined.json\": 97203,\n\t\"./bikescooter.json\": 14321,\n\t\"./biotech.json\": 78099,\n\t\"./biotechoutlined.json\": 62981,\n\t\"./blender.json\": 67969,\n\t\"./blenderoutlined.json\": 9091,\n\t\"./block.json\": 8956,\n\t\"./bloodpressure.json\": 77774,\n\t\"./bloodtype.json\": 33017,\n\t\"./bloodtypeoutlined.json\": 16347,\n\t\"./bluetooth.json\": 64019,\n\t\"./bluetoothaudio.json\": 92039,\n\t\"./bluetoothconnected.json\": 17170,\n\t\"./bluetoothdisabled.json\": 32163,\n\t\"./bluetoothdrive.json\": 74061,\n\t\"./bluetoothdriveoutlined.json\": 81895,\n\t\"./blurcircular.json\": 41187,\n\t\"./blurlinear.json\": 22519,\n\t\"./bluroff.json\": 24331,\n\t\"./bluron.json\": 34303,\n\t\"./bolt.json\": 11396,\n\t\"./book.json\": 29706,\n\t\"./bookmark.json\": 54559,\n\t\"./bookmarkadd.json\": 90222,\n\t\"./bookmarkadded.json\": 39851,\n\t\"./bookmarkaddedoutlined.json\": 86173,\n\t\"./bookmarkaddoutlined.json\": 47288,\n\t\"./bookmarkoutlined.json\": 37593,\n\t\"./bookmarkremove.json\": 69651,\n\t\"./bookmarkremoveoutlined.json\": 49413,\n\t\"./bookmarks.json\": 2188,\n\t\"./bookmarksoutlined.json\": 49358,\n\t\"./bookonline.json\": 20185,\n\t\"./bookonlineoutlined.json\": 3291,\n\t\"./bookoutlined.json\": 25452,\n\t\"./borderall.json\": 35500,\n\t\"./borderbottom.json\": 86926,\n\t\"./borderclear.json\": 34758,\n\t\"./bordercolor.json\": 70656,\n\t\"./bordercoloroutlined.json\": 26346,\n\t\"./borderhorizontal.json\": 19357,\n\t\"./borderinner.json\": 52439,\n\t\"./borderleft.json\": 74776,\n\t\"./borderouter.json\": 89660,\n\t\"./borderright.json\": 20257,\n\t\"./borderstyle.json\": 42362,\n\t\"./bordertop.json\": 44404,\n\t\"./bordervertical.json\": 18643,\n\t\"./brandingwatermark.json\": 54522,\n\t\"./brandingwatermarkoutlined.json\": 34908,\n\t\"./breakfastdining.json\": 44789,\n\t\"./breakfastdiningoutlined.json\": 66415,\n\t\"./brightness1.json\": 97827,\n\t\"./brightness1outlined.json\": 3829,\n\t\"./brightness2.json\": 3122,\n\t\"./brightness2outlined.json\": 63732,\n\t\"./brightness3.json\": 70749,\n\t\"./brightness3outlined.json\": 67255,\n\t\"./brightness4.json\": 83196,\n\t\"./brightness4outlined.json\": 15198,\n\t\"./brightnessauto.json\": 30831,\n\t\"./brightnessautooutlined.json\": 77865,\n\t\"./brightnesshigh.json\": 10484,\n\t\"./brightnesshighoutlined.json\": 46806,\n\t\"./brightnesslow.json\": 9086,\n\t\"./brightnesslowoutlined.json\": 40744,\n\t\"./brightnessmedium.json\": 69623,\n\t\"./brightnessmediumoutlined.json\": 67121,\n\t\"./brokenimage.json\": 61991,\n\t\"./brokenimageoutlined.json\": 27841,\n\t\"./browsernotsupported.json\": 98508,\n\t\"./brunchdining.json\": 88162,\n\t\"./brunchdiningoutlined.json\": 53284,\n\t\"./brush.json\": 16229,\n\t\"./brushoutlined.json\": 59935,\n\t\"./bubblechart.json\": 16023,\n\t\"./bubblechartoutlined.json\": 5041,\n\t\"./bugreport.json\": 77509,\n\t\"./bugreportoutlined.json\": 3903,\n\t\"./build.json\": 19325,\n\t\"./buildcircle.json\": 44153,\n\t\"./buildcircleoutlined.json\": 62683,\n\t\"./buildoutlined.json\": 36343,\n\t\"./bungalow.json\": 19150,\n\t\"./bungalowoutlined.json\": 76408,\n\t\"./burstmode.json\": 33832,\n\t\"./burstmodeoutlined.json\": 96594,\n\t\"./busalert.json\": 35039,\n\t\"./busalertoutlined.json\": 23737,\n\t\"./business.json\": 37993,\n\t\"./businesscenter.json\": 95668,\n\t\"./businesscenteroutlined.json\": 27734,\n\t\"./cabin.json\": 92832,\n\t\"./cable.json\": 79216,\n\t\"./cached.json\": 29949,\n\t\"./cake.json\": 5175,\n\t\"./cakeoutlined.json\": 63441,\n\t\"./calculate.json\": 99725,\n\t\"./calculateoutlined.json\": 8039,\n\t\"./calendartoday.json\": 59086,\n\t\"./calendartodayoutlined.json\": 9336,\n\t\"./calendarviewday.json\": 92778,\n\t\"./calendarviewdayoutlined.json\": 64748,\n\t\"./calendarviewmonth.json\": 14934,\n\t\"./calendarviewweek.json\": 90560,\n\t\"./call.json\": 79299,\n\t\"./callmade.json\": 41746,\n\t\"./callmerge.json\": 22285,\n\t\"./callmissed.json\": 25354,\n\t\"./callmissedoutgoing.json\": 90608,\n\t\"./calloutlined.json\": 6069,\n\t\"./callreceived.json\": 75628,\n\t\"./callsplit.json\": 80693,\n\t\"./calltoaction.json\": 39476,\n\t\"./calltoactionoutlined.json\": 14774,\n\t\"./camera.json\": 11612,\n\t\"./cameraalt.json\": 91959,\n\t\"./cameraaltoutlined.json\": 54129,\n\t\"./cameraenhance.json\": 71994,\n\t\"./cameraenhanceoutlined.json\": 59516,\n\t\"./camerafront.json\": 96555,\n\t\"./camerafrontoutlined.json\": 51005,\n\t\"./cameraindoor.json\": 70395,\n\t\"./cameraindooroutlined.json\": 16845,\n\t\"./cameraoutdoor.json\": 74752,\n\t\"./cameraoutdooroutlined.json\": 31882,\n\t\"./cameraoutlined.json\": 62654,\n\t\"./camerarear.json\": 94950,\n\t\"./camerarearoutlined.json\": 60784,\n\t\"./cameraroll.json\": 3127,\n\t\"./camerarolloutlined.json\": 34097,\n\t\"./cameraswitch.json\": 23680,\n\t\"./cameraswitchoutlined.json\": 64522,\n\t\"./campaign.json\": 96513,\n\t\"./campaignoutlined.json\": 79203,\n\t\"./cancel.json\": 41113,\n\t\"./canceloutlined.json\": 32763,\n\t\"./cancelpresentation.json\": 71549,\n\t\"./cancelschedulesend.json\": 64830,\n\t\"./cancelschedulesendoutlined.json\": 32552,\n\t\"./cardgiftcard.json\": 88005,\n\t\"./cardmembership.json\": 18693,\n\t\"./cardtravel.json\": 88821,\n\t\"./carpenter.json\": 25829,\n\t\"./carpenteroutlined.json\": 87615,\n\t\"./carrental.json\": 98145,\n\t\"./carrentaloutlined.json\": 15395,\n\t\"./carrepair.json\": 24358,\n\t\"./carrepairoutlined.json\": 11760,\n\t\"./cases.json\": 3836,\n\t\"./casesoutlined.json\": 85022,\n\t\"./casino.json\": 59248,\n\t\"./cast.json\": 15884,\n\t\"./castconnected.json\": 61995,\n\t\"./castconnectedoutlined.json\": 94237,\n\t\"./castforeducation.json\": 8651,\n\t\"./castforeducationoutlined.json\": 83101,\n\t\"./catchingpokemon.json\": 37375,\n\t\"./category.json\": 99935,\n\t\"./categoryoutlined.json\": 27961,\n\t\"./celebration.json\": 45841,\n\t\"./celebrationoutlined.json\": 10067,\n\t\"./cellwifi.json\": 27230,\n\t\"./centerfocusstrong.json\": 83657,\n\t\"./centerfocusstrongoutlined.json\": 82027,\n\t\"./chair.json\": 86316,\n\t\"./chairalt.json\": 2631,\n\t\"./chairoutlined.json\": 44878,\n\t\"./chalet.json\": 41932,\n\t\"./chaletoutlined.json\": 15214,\n\t\"./changecircle.json\": 72047,\n\t\"./changecircleoutlined.json\": 56937,\n\t\"./changehistory.json\": 88109,\n\t\"./chargingstation.json\": 18456,\n\t\"./chargingstationoutlined.json\": 19170,\n\t\"./chat.json\": 80001,\n\t\"./chatbubble.json\": 26063,\n\t\"./chatbubbleoutlined.json\": 76937,\n\t\"./chatoutlined.json\": 82787,\n\t\"./check.json\": 56753,\n\t\"./checkbox.json\": 69046,\n\t\"./checkboxoutlineblank.json\": 35249,\n\t\"./checkboxoutlined.json\": 82400,\n\t\"./checkcircle.json\": 66717,\n\t\"./checkcircleoutlined.json\": 47639,\n\t\"./checkroom.json\": 1638,\n\t\"./chevronleft.json\": 73891,\n\t\"./chevronright.json\": 64844,\n\t\"./childcare.json\": 96462,\n\t\"./childfriendly.json\": 61408,\n\t\"./childfriendlyoutlined.json\": 5194,\n\t\"./chromereadermode.json\": 51969,\n\t\"./chromereadermodeoutlined.json\": 25059,\n\t\"./circle.json\": 20571,\n\t\"./circlenotifications.json\": 21617,\n\t\"./circlenotificationsoutlined.json\": 58259,\n\t\"./circleoutlined.json\": 29037,\n\t\"./class.json\": 69793,\n\t\"./classoutlined.json\": 36419,\n\t\"./cleanhands.json\": 47730,\n\t\"./cleanhandsoutlined.json\": 26068,\n\t\"./cleaningservices.json\": 77120,\n\t\"./cleaningservicesoutlined.json\": 13610,\n\t\"./clear.json\": 48924,\n\t\"./clearall.json\": 54159,\n\t\"./close.json\": 13037,\n\t\"./closedcaption.json\": 69212,\n\t\"./closedcaptiondisabled.json\": 19647,\n\t\"./closedcaptiondisabledoutlined.json\": 91673,\n\t\"./closedcaptionoutlined.json\": 27369,\n\t\"./closefluidscreen.json\": 27331,\n\t\"./cloud.json\": 39232,\n\t\"./cloudcircle.json\": 9468,\n\t\"./cloudcircleoutlined.json\": 82398,\n\t\"./clouddone.json\": 57216,\n\t\"./clouddoneoutlined.json\": 98250,\n\t\"./clouddownload.json\": 23080,\n\t\"./clouddownloadoutlined.json\": 80402,\n\t\"./cloudoff.json\": 1953,\n\t\"./cloudoutlined.json\": 33674,\n\t\"./cloudupload.json\": 63749,\n\t\"./clouduploadoutlined.json\": 2015,\n\t\"./code.json\": 8838,\n\t\"./codeoff.json\": 28183,\n\t\"./coffee.json\": 90383,\n\t\"./coffeemaker.json\": 64313,\n\t\"./coffeemakeroutlined.json\": 35675,\n\t\"./coffeeoutlined.json\": 11625,\n\t\"./cognition.json\": 42153,\n\t\"./collections.json\": 4712,\n\t\"./collectionsbookmark.json\": 90464,\n\t\"./collectionsbookmarkoutlined.json\": 10442,\n\t\"./collectionsoutlined.json\": 53106,\n\t\"./colorize.json\": 43940,\n\t\"./colorizeoutlined.json\": 88774,\n\t\"./comment.json\": 26484,\n\t\"./commentbank.json\": 98510,\n\t\"./commentbankoutlined.json\": 69560,\n\t\"./commentoutlined.json\": 65430,\n\t\"./commute.json\": 76997,\n\t\"./compare.json\": 74742,\n\t\"./comparearrows.json\": 41884,\n\t\"./compasscalibration.json\": 73683,\n\t\"./compasscalibrationoutlined.json\": 98405,\n\t\"./compost.json\": 17702,\n\t\"./compress.json\": 40647,\n\t\"./computer.json\": 87542,\n\t\"./confirmationnumber.json\": 82419,\n\t\"./confirmationnumberoutlined.json\": 63717,\n\t\"./connectedtv.json\": 62240,\n\t\"./connectwithoutcontact.json\": 17751,\n\t\"./construction.json\": 80118,\n\t\"./contactless.json\": 34848,\n\t\"./contactlessoutlined.json\": 64746,\n\t\"./contactmail.json\": 66354,\n\t\"./contactmailoutlined.json\": 308,\n\t\"./contactpage.json\": 73562,\n\t\"./contactpageoutlined.json\": 8252,\n\t\"./contactphone.json\": 97519,\n\t\"./contactphoneoutlined.json\": 6793,\n\t\"./contacts.json\": 13638,\n\t\"./contactsoutlined.json\": 52592,\n\t\"./contactsupport.json\": 99840,\n\t\"./contactsupportoutlined.json\": 45482,\n\t\"./contentcopy.json\": 87469,\n\t\"./contentcut.json\": 85332,\n\t\"./contentpaste.json\": 63695,\n\t\"./contentpasteoff.json\": 66956,\n\t\"./controlcamera.json\": 15795,\n\t\"./controlpoint.json\": 59358,\n\t\"./controlpointduplicate.json\": 9627,\n\t\"./copyall.json\": 72069,\n\t\"./copyright.json\": 16616,\n\t\"./coronavirus.json\": 74116,\n\t\"./coronavirusoutlined.json\": 99750,\n\t\"./corporatefare.json\": 1978,\n\t\"./cottage.json\": 46028,\n\t\"./cottageoutlined.json\": 28814,\n\t\"./countertops.json\": 6633,\n\t\"./countertopsoutlined.json\": 37099,\n\t\"./create.json\": 56315,\n\t\"./createnewfolder.json\": 46687,\n\t\"./createnewfolderoutlined.json\": 48441,\n\t\"./createoutlined.json\": 18317,\n\t\"./creditcard.json\": 54704,\n\t\"./creditcardoff.json\": 99377,\n\t\"./creditcardoffoutlined.json\": 96787,\n\t\"./creditscore.json\": 86128,\n\t\"./crib.json\": 54041,\n\t\"./criboutlined.json\": 6363,\n\t\"./crop.json\": 16989,\n\t\"./crop169.json\": 70461,\n\t\"./crop32.json\": 85740,\n\t\"./crop54.json\": 26368,\n\t\"./crop75.json\": 24201,\n\t\"./cropdin.json\": 22268,\n\t\"./cropfree.json\": 97719,\n\t\"./croplandscape.json\": 15954,\n\t\"./croporiginal.json\": 33298,\n\t\"./cropportrait.json\": 92090,\n\t\"./croprotate.json\": 31434,\n\t\"./cropsquare.json\": 25518,\n\t\"./dangerous.json\": 9117,\n\t\"./dangerousoutlined.json\": 68407,\n\t\"./darkmode.json\": 55468,\n\t\"./darkmodeoutlined.json\": 70862,\n\t\"./dashboard.json\": 70121,\n\t\"./dashboardcustomize.json\": 32224,\n\t\"./dashboardcustomizeoutlined.json\": 16458,\n\t\"./dashboardoutlined.json\": 21899,\n\t\"./datasaveroff.json\": 6413,\n\t\"./datasaveron.json\": 97513,\n\t\"./delete.json\": 7968,\n\t\"./deleteforever.json\": 70839,\n\t\"./deleteforeveroutlined.json\": 52177,\n\t\"./deleteoutlined.json\": 42666,\n\t\"./deletesweepoutlined.json\": 21090,\n\t\"./deliverydining.json\": 65878,\n\t\"./deliverydiningoutlined.json\": 18752,\n\t\"./departureboard.json\": 33575,\n\t\"./departureboardoutlined.json\": 29473,\n\t\"./description.json\": 52319,\n\t\"./descriptionoutlined.json\": 31033,\n\t\"./designservices.json\": 28533,\n\t\"./designservicesoutlined.json\": 27215,\n\t\"./desktopaccessdisabled.json\": 24599,\n\t\"./desktopmac.json\": 76644,\n\t\"./desktopwindows.json\": 84458,\n\t\"./details.json\": 49515,\n\t\"./developerboard.json\": 70837,\n\t\"./developerboardoff.json\": 10018,\n\t\"./devicehub.json\": 60928,\n\t\"./devices.json\": 77218,\n\t\"./devicesother.json\": 23196,\n\t\"./devicethermostat.json\": 57000,\n\t\"./deviceunknown.json\": 26729,\n\t\"./dialersip.json\": 17118,\n\t\"./dialersipoutlined.json\": 22024,\n\t\"./dialpad.json\": 11626,\n\t\"./dining.json\": 88022,\n\t\"./diningoutlined.json\": 62720,\n\t\"./dinnerdining.json\": 82834,\n\t\"./dinnerdiningoutlined.json\": 53108,\n\t\"./directions.json\": 60753,\n\t\"./directionsbike.json\": 34432,\n\t\"./directionsboat.json\": 20059,\n\t\"./directionsboatoutlined.json\": 78669,\n\t\"./directionsbus.json\": 98957,\n\t\"./directionsbusoutlined.json\": 30023,\n\t\"./directionscar.json\": 84781,\n\t\"./directionscaroutlined.json\": 42599,\n\t\"./directionsoff.json\": 97198,\n\t\"./directionsoutlined.json\": 17587,\n\t\"./directionsrailway.json\": 6384,\n\t\"./directionsrailwayoutlined.json\": 49306,\n\t\"./directionsrun.json\": 5846,\n\t\"./directionssubway.json\": 29852,\n\t\"./directionssubwayoutlined.json\": 65086,\n\t\"./directionswalk.json\": 80896,\n\t\"./dirtylens.json\": 50517,\n\t\"./dirtylensoutlined.json\": 96047,\n\t\"./disabledbydefault.json\": 37323,\n\t\"./disabledbydefaultoutlined.json\": 66749,\n\t\"./discfluid.json\": 95670,\n\t\"./discfluidoutlined.json\": 92576,\n\t\"./dns.json\": 67546,\n\t\"./dnsoutlined.json\": 21788,\n\t\"./dock.json\": 69612,\n\t\"./documentscanneroutlined.json\": 54574,\n\t\"./documentscannerrounded.json\": 1273,\n\t\"./dodisturb.json\": 35745,\n\t\"./dodisturbalt.json\": 98940,\n\t\"./dodisturboff.json\": 10782,\n\t\"./dodisturboffoutlined.json\": 74568,\n\t\"./dodisturbon.json\": 32400,\n\t\"./dodisturbonoutlined.json\": 67706,\n\t\"./domain.json\": 46639,\n\t\"./domaindisabled.json\": 81311,\n\t\"./domainverification.json\": 10160,\n\t\"./done.json\": 17687,\n\t\"./doneall.json\": 27238,\n\t\"./doneoutline.json\": 50499,\n\t\"./donotdisturb.json\": 99450,\n\t\"./donotdisturbalt.json\": 84585,\n\t\"./donotdisturboff.json\": 36667,\n\t\"./donotdisturboffoutlined.json\": 20685,\n\t\"./donotdisturbon.json\": 8655,\n\t\"./donotdisturbonoutlined.json\": 38409,\n\t\"./donotdisturbontotalsilence.json\": 39818,\n\t\"./donotstep.json\": 27021,\n\t\"./donotstepoutlined.json\": 70983,\n\t\"./donottouch.json\": 31574,\n\t\"./donottouchoutlined.json\": 75360,\n\t\"./donutlarge.json\": 72496,\n\t\"./donutsmall.json\": 75304,\n\t\"./donutsmalloutlined.json\": 83474,\n\t\"./doorback.json\": 60620,\n\t\"./doorbell.json\": 68774,\n\t\"./doorbelloutlined.json\": 3344,\n\t\"./doorfront.json\": 6806,\n\t\"./doorfrontoutlined.json\": 4416,\n\t\"./doorsliding.json\": 24463,\n\t\"./doorslidingoutlined.json\": 97097,\n\t\"./doublearrow.json\": 49011,\n\t\"./downhillskiing.json\": 77751,\n\t\"./download.json\": 91319,\n\t\"./downloaddone.json\": 40491,\n\t\"./downloadforoffline.json\": 36289,\n\t\"./downloadforofflineoutlined.json\": 18115,\n\t\"./downloading.json\": 65685,\n\t\"./downloadoutlined.json\": 61969,\n\t\"./drafts.json\": 56519,\n\t\"./draftsoutlined.json\": 72609,\n\t\"./draghandle.json\": 61847,\n\t\"./dragindicator.json\": 82638,\n\t\"./driveeta.json\": 30587,\n\t\"./driveetaoutlined.json\": 11757,\n\t\"./drivefilemove.json\": 14874,\n\t\"./drivefilemoveoutlined.json\": 41148,\n\t\"./drivefilerenameoutline.json\": 1337,\n\t\"./drivefolderupload.json\": 97880,\n\t\"./drivefolderuploadoutlined.json\": 58882,\n\t\"./dry.json\": 18940,\n\t\"./drycleaning.json\": 75371,\n\t\"./drycleaningoutlined.json\": 34493,\n\t\"./dryoutlined.json\": 51518,\n\t\"./duo.json\": 20617,\n\t\"./dvr.json\": 84685,\n\t\"./dynamicfeed.json\": 81292,\n\t\"./dynamicform.json\": 86722,\n\t\"./dynamicformoutlined.json\": 10468,\n\t\"./earbuds.json\": 35485,\n\t\"./earbudsbattery.json\": 83798,\n\t\"./earbudsoutlined.json\": 96919,\n\t\"./east.json\": 40394,\n\t\"./edgesensorhigh.json\": 74812,\n\t\"./edgesensorhighoutlined.json\": 61694,\n\t\"./edgesensorlow.json\": 47622,\n\t\"./edgesensorlowoutlined.json\": 20400,\n\t\"./edit.json\": 44575,\n\t\"./editattributes.json\": 52054,\n\t\"./editattributesoutlined.json\": 8448,\n\t\"./editlocation.json\": 42184,\n\t\"./editlocationalt.json\": 37275,\n\t\"./editlocationaltoutlined.json\": 59213,\n\t\"./editlocationoutlined.json\": 2898,\n\t\"./editnotifications.json\": 25685,\n\t\"./editnotificationsoutlined.json\": 23471,\n\t\"./editoff.json\": 27228,\n\t\"./editoffoutlined.json\": 27934,\n\t\"./editoutlined.json\": 37305,\n\t\"./editroad.json\": 15633,\n\t\"./eightk.json\": 46831,\n\t\"./eightkoutlined.json\": 83401,\n\t\"./eightkplus.json\": 22667,\n\t\"./eightkplusoutlined.json\": 88893,\n\t\"./eightmp.json\": 45459,\n\t\"./eightmpoutlined.json\": 325,\n\t\"./eightteenmp.json\": 84635,\n\t\"./eightteenmpoutlined.json\": 53933,\n\t\"./eject.json\": 98056,\n\t\"./ejectoutlined.json\": 80530,\n\t\"./elderly.json\": 72522,\n\t\"./electricalservices.json\": 28729,\n\t\"./electricbike.json\": 28297,\n\t\"./electriccar.json\": 94434,\n\t\"./electriccaroutlined.json\": 35748,\n\t\"./electricmoped.json\": 32517,\n\t\"./electricmopedoutlined.json\": 49823,\n\t\"./electricrickshaw.json\": 71988,\n\t\"./electricrickshawoutlined.json\": 26966,\n\t\"./electricscooter.json\": 82855,\n\t\"./elevator.json\": 51877,\n\t\"./elevatoroutlined.json\": 607,\n\t\"./elevenmp.json\": 26395,\n\t\"./elevenmpoutlined.json\": 70221,\n\t\"./email.json\": 22357,\n\t\"./emailoutlined.json\": 29615,\n\t\"./emobiledata.json\": 56276,\n\t\"./emojiemotions.json\": 13873,\n\t\"./emojiemotionsoutlined.json\": 37715,\n\t\"./emojievents.json\": 63070,\n\t\"./emojieventsoutlined.json\": 30632,\n\t\"./emojiflags.json\": 34954,\n\t\"./emojifoodbeverage.json\": 6642,\n\t\"./emojifoodbeverageoutlined.json\": 1748,\n\t\"./emojinature.json\": 4620,\n\t\"./emojinatureoutlined.json\": 57966,\n\t\"./emojiobjects.json\": 15697,\n\t\"./emojiobjectsoutlined.json\": 35731,\n\t\"./emojipeople.json\": 16100,\n\t\"./emojisymbols.json\": 44812,\n\t\"./emojitransportation.json\": 17549,\n\t\"./endocrinology.json\": 80061,\n\t\"./engineering.json\": 45918,\n\t\"./engineeringoutlined.json\": 60072,\n\t\"./enhancedencryption.json\": 55696,\n\t\"./enhancedencryptionoutlined.json\": 35482,\n\t\"./equalizer.json\": 9397,\n\t\"./error.json\": 77635,\n\t\"./erroroutlined.json\": 57653,\n\t\"./escalator.json\": 9249,\n\t\"./escalatoroutlined.json\": 50627,\n\t\"./escalatorwarning.json\": 64671,\n\t\"./euro.json\": 94466,\n\t\"./event.json\": 98277,\n\t\"./eventavailable.json\": 22108,\n\t\"./eventavailableoutlined.json\": 80158,\n\t\"./eventbusy.json\": 67732,\n\t\"./eventbusyoutlined.json\": 24598,\n\t\"./eventnote.json\": 13565,\n\t\"./eventnoteoutlined.json\": 57943,\n\t\"./eventoutlined.json\": 94367,\n\t\"./eventseat.json\": 84940,\n\t\"./eventseatoutlined.json\": 34222,\n\t\"./evstation.json\": 99800,\n\t\"./evstationoutlined.json\": 80706,\n\t\"./exittoapp.json\": 55465,\n\t\"./expand.json\": 10003,\n\t\"./expandless.json\": 20226,\n\t\"./expandmore.json\": 26970,\n\t\"./explicit.json\": 28323,\n\t\"./explicitoutlined.json\": 70613,\n\t\"./explore.json\": 32722,\n\t\"./exploreoff.json\": 75955,\n\t\"./exploreoffoutlined.json\": 28261,\n\t\"./exploreoutlined.json\": 1140,\n\t\"./exposure.json\": 72134,\n\t\"./exposureoutlined.json\": 8560,\n\t\"./extension.json\": 38004,\n\t\"./extensionoff.json\": 97717,\n\t\"./extensionoffoutlined.json\": 60271,\n\t\"./extensionoutlined.json\": 18454,\n\t\"./face.json\": 58318,\n\t\"./facebook.json\": 24999,\n\t\"./facebookoutlined.json\": 84033,\n\t\"./faceoutlined.json\": 98552,\n\t\"./faceretouchingnatural.json\": 22503,\n\t\"./faceretouchingnaturaloutlined.json\": 41377,\n\t\"./faceretouchingoff.json\": 56775,\n\t\"./faceretouchingoffoutlined.json\": 75617,\n\t\"./factcheck.json\": 88823,\n\t\"./factcheckoutlined.json\": 18577,\n\t\"./familyrestroom.json\": 73198,\n\t\"./farsightdigital.json\": 80631,\n\t\"./fastfood.json\": 36949,\n\t\"./fastfoodoutlined.json\": 81711,\n\t\"./fastforward.json\": 29582,\n\t\"./fastforwardoutlined.json\": 34936,\n\t\"./fastrewind.json\": 24034,\n\t\"./fastrewindoutlined.json\": 78852,\n\t\"./favorite.json\": 65459,\n\t\"./favoriteoutlined.json\": 44549,\n\t\"./featuredplaylist.json\": 53655,\n\t\"./featuredplaylistoutlined.json\": 37041,\n\t\"./featuredvideo.json\": 5808,\n\t\"./featuredvideooutlined.json\": 10554,\n\t\"./feed.json\": 95607,\n\t\"./feedback.json\": 70216,\n\t\"./feedbackoutlined.json\": 53650,\n\t\"./feedoutlined.json\": 14673,\n\t\"./female.json\": 67555,\n\t\"./fence.json\": 52996,\n\t\"./festival.json\": 2991,\n\t\"./festivaloutlined.json\": 15017,\n\t\"./fiberdvr.json\": 3193,\n\t\"./fiberdvroutlined.json\": 20539,\n\t\"./fibermanualrecord.json\": 19416,\n\t\"./fibermanualrecordoutlined.json\": 74530,\n\t\"./fibernew.json\": 53351,\n\t\"./fibernewoutlined.json\": 3137,\n\t\"./fiberpin.json\": 86194,\n\t\"./fiberpinoutlined.json\": 43476,\n\t\"./fibersmartrecord.json\": 44177,\n\t\"./fibersmartrecordoutlined.json\": 93107,\n\t\"./filecopy.json\": 4,\n\t\"./filecopyoutlined.json\": 75302,\n\t\"./filedownload.json\": 84677,\n\t\"./filedownloaddone.json\": 32585,\n\t\"./filedownloaddoneoutlined.json\": 64075,\n\t\"./filedownloadoff.json\": 99538,\n\t\"./filedownloadoffoutlined.json\": 79892,\n\t\"./filedownloadoutlined.json\": 72383,\n\t\"./filepresent.json\": 38508,\n\t\"./fileupload.json\": 67396,\n\t\"./fileuploadoutlined.json\": 41958,\n\t\"./filter.json\": 83865,\n\t\"./filter1.json\": 35140,\n\t\"./filter2.json\": 3601,\n\t\"./filter3.json\": 20022,\n\t\"./filter4.json\": 88811,\n\t\"./filter5.json\": 79944,\n\t\"./filter6.json\": 65861,\n\t\"./filter7.json\": 45530,\n\t\"./filter8.json\": 82463,\n\t\"./filter9.json\": 57100,\n\t\"./filter9plus.json\": 39020,\n\t\"./filteralt.json\": 60340,\n\t\"./filteraltoutlined.json\": 566,\n\t\"./filterbandw.json\": 67963,\n\t\"./filtercenterfocus.json\": 13980,\n\t\"./filterdrama.json\": 85136,\n\t\"./filterframes.json\": 25031,\n\t\"./filterframesoutlined.json\": 33281,\n\t\"./filterhdr.json\": 16893,\n\t\"./filterhdroutlined.json\": 58583,\n\t\"./filterline.json\": 87919,\n\t\"./filterlist.json\": 66317,\n\t\"./filternone.json\": 10592,\n\t\"./filtertiltshift.json\": 34858,\n\t\"./filtervintage.json\": 71801,\n\t\"./filtervintageoutlined.json\": 5499,\n\t\"./findinpage.json\": 74940,\n\t\"./findinpageoutlined.json\": 21022,\n\t\"./findreplace.json\": 80256,\n\t\"./fingerprint.json\": 67833,\n\t\"./fireextinguisher.json\": 78872,\n\t\"./fireplace.json\": 62066,\n\t\"./fireplaceoutlined.json\": 83572,\n\t\"./firstpage.json\": 19580,\n\t\"./fitnesscenter.json\": 28048,\n\t\"./fitscreen.json\": 68442,\n\t\"./fitscreenoutlined.json\": 36956,\n\t\"./fiveg.json\": 47124,\n\t\"./fivek.json\": 12096,\n\t\"./fivekoutlined.json\": 80170,\n\t\"./fivekplus.json\": 49072,\n\t\"./fivekplusoutlined.json\": 20762,\n\t\"./fivemp.json\": 84354,\n\t\"./fivempoutlined.json\": 5860,\n\t\"./fivteenmp.json\": 68041,\n\t\"./fivteenmpoutlined.json\": 57707,\n\t\"./flag.json\": 14017,\n\t\"./flagoutlined.json\": 86211,\n\t\"./flaky.json\": 29288,\n\t\"./flare.json\": 77797,\n\t\"./flashauto.json\": 48512,\n\t\"./flashlightoff.json\": 65446,\n\t\"./flashlightoffoutlined.json\": 67760,\n\t\"./flashlighton.json\": 66456,\n\t\"./flashlightonoutlined.json\": 39586,\n\t\"./flashoff.json\": 99232,\n\t\"./flashon.json\": 3194,\n\t\"./flatware.json\": 16189,\n\t\"./flight.json\": 41005,\n\t\"./flightland.json\": 45696,\n\t\"./flighttakeoff.json\": 87967,\n\t\"./flip.json\": 87472,\n\t\"./flipcameraandroid.json\": 12018,\n\t\"./flipcameraios.json\": 10116,\n\t\"./flipcameraiosoutlined.json\": 41094,\n\t\"./fliptoback.json\": 74034,\n\t\"./fliptofront.json\": 14468,\n\t\"./flourescent.json\": 74771,\n\t\"./flourescentoutlined.json\": 88997,\n\t\"./fluidmed.json\": 96177,\n\t\"./flutterdash.json\": 80783,\n\t\"./fmdbad.json\": 41325,\n\t\"./fmdbadoutlined.json\": 63815,\n\t\"./fmdgood.json\": 36839,\n\t\"./fmdgoodoutlined.json\": 9953,\n\t\"./folder.json\": 4599,\n\t\"./folderopen.json\": 70347,\n\t\"./folderoutlined.json\": 62609,\n\t\"./foldershared.json\": 84002,\n\t\"./foldersharedoutlined.json\": 58532,\n\t\"./folderspecial.json\": 3138,\n\t\"./folderspecialoutlined.json\": 6532,\n\t\"./followthesigns.json\": 32537,\n\t\"./fontdownload.json\": 84838,\n\t\"./fontdownloadoff.json\": 44983,\n\t\"./fontdownloadoffoutlined.json\": 15665,\n\t\"./fontdownloadoutlined.json\": 12144,\n\t\"./foodbank.json\": 67629,\n\t\"./foodbankoutlined.json\": 22311,\n\t\"./footbones.json\": 11754,\n\t\"./formataligncenter.json\": 70872,\n\t\"./formatalignjustify.json\": 45907,\n\t\"./formatalignleft.json\": 89324,\n\t\"./formatalignright.json\": 4349,\n\t\"./formatbold.json\": 37671,\n\t\"./formatclear.json\": 67485,\n\t\"./formatcolorfill.json\": 11838,\n\t\"./formatcolorreset.json\": 9670,\n\t\"./formatcolorresetoutlined.json\": 46256,\n\t\"./formatcolortext.json\": 10420,\n\t\"./formatindentdecrease.json\": 21886,\n\t\"./formatindentincrease.json\": 13294,\n\t\"./formatitalic.json\": 13476,\n\t\"./formatlinespacing.json\": 25987,\n\t\"./formatlistbulleted.json\": 50817,\n\t\"./formatlistnumbered.json\": 96804,\n\t\"./formatlistnumberedrtl.json\": 14734,\n\t\"./formatpaint.json\": 48648,\n\t\"./formatpaintoutlined.json\": 70194,\n\t\"./formatquote.json\": 91840,\n\t\"./formatquoteoutlined.json\": 97258,\n\t\"./formatshapes.json\": 3002,\n\t\"./formatsize.json\": 60281,\n\t\"./formatstrikethrough.json\": 56391,\n\t\"./formattextdirectionltor.json\": 86237,\n\t\"./formattextdirectionltoroutlined.json\": 52823,\n\t\"./formattextdirectionrtol.json\": 88629,\n\t\"./formattextdirectionrtoloutlined.json\": 84207,\n\t\"./formatunderlined.json\": 8460,\n\t\"./forum.json\": 44428,\n\t\"./forumoutlined.json\": 29422,\n\t\"./forward.json\": 80240,\n\t\"./forward10.json\": 87773,\n\t\"./forward30.json\": 93979,\n\t\"./forward5.json\": 39975,\n\t\"./forwardoutlined.json\": 57498,\n\t\"./foundation.json\": 31277,\n\t\"./fourgmobiledata.json\": 64102,\n\t\"./fourgplusmobiledata.json\": 44102,\n\t\"./fourk.json\": 32988,\n\t\"./fourkoutlined.json\": 30910,\n\t\"./fourkplus.json\": 72316,\n\t\"./fourkplusoutlined.json\": 5662,\n\t\"./fourmp.json\": 33454,\n\t\"./fourmpoutlined.json\": 16952,\n\t\"./fourteenmp.json\": 6574,\n\t\"./fourteenmpoutlined.json\": 99608,\n\t\"./freebreakfast.json\": 76726,\n\t\"./freebreakfastoutlined.json\": 93504,\n\t\"./fullscreen.json\": 68286,\n\t\"./fullscreenexit.json\": 40198,\n\t\"./functions.json\": 27080,\n\t\"./games.json\": 4418,\n\t\"./gamesoutlined.json\": 4132,\n\t\"./garage.json\": 12250,\n\t\"./garageoutlined.json\": 18588,\n\t\"./gastroenterology.json\": 52629,\n\t\"./gavel.json\": 1462,\n\t\"./gesture.json\": 35606,\n\t\"./getapp.json\": 31412,\n\t\"./getappoutlined.json\": 69942,\n\t\"./gif.json\": 11491,\n\t\"./gite.json\": 98764,\n\t\"./github.json\": 83568,\n\t\"./gmobiledata.json\": 9122,\n\t\"./golfcourse.json\": 31666,\n\t\"./google.json\": 85852,\n\t\"./gppbad.json\": 35639,\n\t\"./gppbadoutlined.json\": 79889,\n\t\"./gppgood.json\": 81813,\n\t\"./gppgoodoutlined.json\": 20975,\n\t\"./gppmaybe.json\": 54096,\n\t\"./gppmaybeoutlined.json\": 90970,\n\t\"./gpsfixed.json\": 73165,\n\t\"./gpsnotfixed.json\": 30860,\n\t\"./gpsoff.json\": 43294,\n\t\"./grade.json\": 73322,\n\t\"./gradeoutlined.json\": 61964,\n\t\"./gradient.json\": 31023,\n\t\"./grading.json\": 9669,\n\t\"./grain.json\": 86606,\n\t\"./graphiceq.json\": 52903,\n\t\"./grass.json\": 71399,\n\t\"./grid3x3.json\": 25185,\n\t\"./grid4x4.json\": 68137,\n\t\"./gridgoldenratio.json\": 58981,\n\t\"./gridoff.json\": 3388,\n\t\"./gridon.json\": 19910,\n\t\"./gridview.json\": 78030,\n\t\"./group.json\": 9662,\n\t\"./groupadd.json\": 28605,\n\t\"./groupaddoutlined.json\": 86551,\n\t\"./groups.json\": 60355,\n\t\"./groupsoutlined.json\": 59765,\n\t\"./groupwork.json\": 32983,\n\t\"./groupworkoutlined.json\": 56849,\n\t\"./gtranslate.json\": 35206,\n\t\"./gtranslateoutlined.json\": 68432,\n\t\"./gynecology.json\": 62849,\n\t\"./hail.json\": 31801,\n\t\"./handyman.json\": 62731,\n\t\"./handymanoutlined.json\": 79485,\n\t\"./hardware.json\": 72019,\n\t\"./hardwareoutlined.json\": 90373,\n\t\"./hd.json\": 2447,\n\t\"./hdoutlined.json\": 93545,\n\t\"./hdrauto.json\": 6756,\n\t\"./hdrautooutlined.json\": 63110,\n\t\"./hdrautoselect.json\": 91004,\n\t\"./hdrenhancedselect.json\": 85065,\n\t\"./hdroff.json\": 90124,\n\t\"./hdroffselect.json\": 59284,\n\t\"./hdron.json\": 7606,\n\t\"./hdronselect.json\": 21790,\n\t\"./hdrplus.json\": 779,\n\t\"./hdrplusoutlined.json\": 74717,\n\t\"./hdrweak.json\": 74451,\n\t\"./headphones.json\": 90648,\n\t\"./headphonesoutlined.json\": 29762,\n\t\"./headset.json\": 35247,\n\t\"./headsetmic.json\": 31462,\n\t\"./headsetmicoutlined.json\": 90416,\n\t\"./headsetoff.json\": 31564,\n\t\"./headsetoffoutlined.json\": 41902,\n\t\"./headsetoutlined.json\": 45481,\n\t\"./healing.json\": 22959,\n\t\"./healthandsafety.json\": 41028,\n\t\"./healthandsafetyoutlined.json\": 58854,\n\t\"./hearing.json\": 97885,\n\t\"./hearingdisabled.json\": 59709,\n\t\"./height.json\": 11308,\n\t\"./help.json\": 13296,\n\t\"./helpcenter.json\": 41965,\n\t\"./helpcenteroutlined.json\": 25479,\n\t\"./helpoutlined.json\": 17850,\n\t\"./hevc.json\": 79343,\n\t\"./hideimage.json\": 12888,\n\t\"./hideimageoutlined.json\": 27381,\n\t\"./hidesource.json\": 32442,\n\t\"./highlight.json\": 84741,\n\t\"./highlightalt.json\": 91256,\n\t\"./highlightoff.json\": 3154,\n\t\"./highlightoutlined.json\": 67839,\n\t\"./highquality.json\": 44596,\n\t\"./highqualityoutlined.json\": 97462,\n\t\"./hiking.json\": 80063,\n\t\"./history.json\": 29185,\n\t\"./historyedu.json\": 53163,\n\t\"./historytoggleoff.json\": 14302,\n\t\"./hmobiledata.json\": 26339,\n\t\"./holidayvillage.json\": 36095,\n\t\"./holidayvillageoutlined.json\": 2841,\n\t\"./home.json\": 35480,\n\t\"./homemax.json\": 93266,\n\t\"./homemini.json\": 57695,\n\t\"./homeoutlined.json\": 96674,\n\t\"./homerepairservice.json\": 72828,\n\t\"./homerepairserviceoutlined.json\": 77214,\n\t\"./homework.json\": 95425,\n\t\"./homeworkoutlined.json\": 57283,\n\t\"./horizontalrule.json\": 3185,\n\t\"./horizontalsplit.json\": 86101,\n\t\"./hotel.json\": 12219,\n\t\"./hoteloutlined.json\": 88493,\n\t\"./hottub.json\": 88089,\n\t\"./hourglassbottom.json\": 36196,\n\t\"./hourglassdisabled.json\": 41419,\n\t\"./hourglassempty.json\": 71096,\n\t\"./hourglassfull.json\": 77714,\n\t\"./hourglasstop.json\": 66686,\n\t\"./house.json\": 14441,\n\t\"./houseboat.json\": 11363,\n\t\"./houseboatoutlined.json\": 32725,\n\t\"./houseoutlined.json\": 77323,\n\t\"./housesiding.json\": 8909,\n\t\"./howtoreg.json\": 6504,\n\t\"./howtoregoutlined.json\": 20178,\n\t\"./howtovote.json\": 3258,\n\t\"./howtovoteoutlined.json\": 43932,\n\t\"./hplusmobiledata.json\": 37395,\n\t\"./http.json\": 8131,\n\t\"./https.json\": 14232,\n\t\"./httpsoutlined.json\": 57890,\n\t\"./humidityindoor.json\": 777,\n\t\"./hvac.json\": 31377,\n\t\"./hvacoutlined.json\": 15731,\n\t\"./icecream.json\": 70112,\n\t\"./icecreamoutlined.json\": 51722,\n\t\"./iceskating.json\": 92239,\n\t\"./iceskatingoutlined.json\": 96393,\n\t\"./image.json\": 50888,\n\t\"./imageaspectratio.json\": 45075,\n\t\"./imagenotsupported.json\": 13081,\n\t\"./imagenotsupportedoutlined.json\": 38715,\n\t\"./imageoutlined.json\": 8594,\n\t\"./imagesearch.json\": 53956,\n\t\"./imagesearchroller.json\": 46444,\n\t\"./imagesearchrolleroutlined.json\": 80622,\n\t\"./immunology.json\": 19589,\n\t\"./importantdevices.json\": 40010,\n\t\"./importcontacts.json\": 2763,\n\t\"./importexport.json\": 79192,\n\t\"./inbox.json\": 58741,\n\t\"./inboxoutlined.json\": 48879,\n\t\"./indeterminatecheckbox.json\": 16299,\n\t\"./indeterminatecheckboxoutlined.json\": 52061,\n\t\"./info.json\": 1815,\n\t\"./infooutlined.json\": 34417,\n\t\"./input.json\": 45941,\n\t\"./insertchart.json\": 99898,\n\t\"./insertchartoutlined.json\": 78876,\n\t\"./insertcomment.json\": 24103,\n\t\"./insertcommentoutlined.json\": 66529,\n\t\"./insertdrivefile.json\": 67984,\n\t\"./insertdrivefileoutlined.json\": 34778,\n\t\"./insights.json\": 3218,\n\t\"./instagram.json\": 39761,\n\t\"./integrationinstructions.json\": 99562,\n\t\"./inventory.json\": 51777,\n\t\"./inventory2.json\": 18537,\n\t\"./inventoryoutlined.json\": 50083,\n\t\"./invertcolors.json\": 25163,\n\t\"./invertcolorsoff.json\": 77320,\n\t\"./iosshare.json\": 26651,\n\t\"./iron.json\": 73625,\n\t\"./ironoutlined.json\": 22907,\n\t\"./iso.json\": 34984,\n\t\"./kayaking.json\": 78914,\n\t\"./keyboard.json\": 68310,\n\t\"./keyboardalt.json\": 64173,\n\t\"./keyboardaltoutlined.json\": 17319,\n\t\"./keyboardarrowdown.json\": 36019,\n\t\"./keyboardarrowleft.json\": 92458,\n\t\"./keyboardarrowright.json\": 74235,\n\t\"./keyboardarrowup.json\": 79374,\n\t\"./keyboardbackspace.json\": 1845,\n\t\"./keyboardcapslock.json\": 41012,\n\t\"./keyboardcommandkey.json\": 22158,\n\t\"./keyboardhide.json\": 15158,\n\t\"./keyboardhideoutlined.json\": 32480,\n\t\"./keyboardreturn.json\": 44452,\n\t\"./keyboardtab.json\": 64101,\n\t\"./keyboardvoice.json\": 10428,\n\t\"./keyboardvoiceoutlined.json\": 63134,\n\t\"./kingbed.json\": 70519,\n\t\"./kingbedoutlined.json\": 59505,\n\t\"./kitchen.json\": 78345,\n\t\"./kitesurfing.json\": 55036,\n\t\"./label.json\": 60443,\n\t\"./labelimportant.json\": 45971,\n\t\"./labeloff.json\": 32408,\n\t\"./labeloffoutlined.json\": 67426,\n\t\"./labeloutlined.json\": 86765,\n\t\"./landscape.json\": 79592,\n\t\"./landscapeoutlined.json\": 59378,\n\t\"./landslide.json\": 65051,\n\t\"./language.json\": 30561,\n\t\"./laptop.json\": 64447,\n\t\"./laptopchromebook.json\": 25884,\n\t\"./laptopmac.json\": 97022,\n\t\"./laptopwindows.json\": 16884,\n\t\"./lastpage.json\": 86184,\n\t\"./launch.json\": 26572,\n\t\"./layers.json\": 68953,\n\t\"./layersclear.json\": 84614,\n\t\"./layersclearoutlined.json\": 47184,\n\t\"./layersoutlined.json\": 31515,\n\t\"./leaderboard.json\": 93514,\n\t\"./leaderboardoutlined.json\": 70412,\n\t\"./leakadd.json\": 42555,\n\t\"./leakremove.json\": 72336,\n\t\"./legendtoggle.json\": 1438,\n\t\"./libraryadd.json\": 54233,\n\t\"./libraryaddcheck.json\": 53399,\n\t\"./libraryaddcheckoutlined.json\": 80273,\n\t\"./libraryaddoutlined.json\": 55899,\n\t\"./librarybooks.json\": 78560,\n\t\"./librarybooksoutlined.json\": 87338,\n\t\"./librarymusic.json\": 80305,\n\t\"./librarymusicoutlined.json\": 88211,\n\t\"./light.json\": 95065,\n\t\"./lightbulb.json\": 66414,\n\t\"./lightbulboutlined.json\": 62968,\n\t\"./lightmode.json\": 17134,\n\t\"./lightmodeoutlined.json\": 20523,\n\t\"./linearscale.json\": 22068,\n\t\"./linestyle.json\": 80886,\n\t\"./lineweight.json\": 84177,\n\t\"./link.json\": 70847,\n\t\"./linkedcamera.json\": 58129,\n\t\"./linkedcameraoutlined.json\": 92627,\n\t\"./linkedin.json\": 47877,\n\t\"./linkoff.json\": 29436,\n\t\"./list.json\": 91291,\n\t\"./listalt.json\": 69805,\n\t\"./livehelp.json\": 34282,\n\t\"./livehelpoutlined.json\": 14668,\n\t\"./livetv.json\": 51715,\n\t\"./living.json\": 15382,\n\t\"./livingoutlined.json\": 5248,\n\t\"./localactivity.json\": 72623,\n\t\"./localactivityoutlined.json\": 79017,\n\t\"./localatm.json\": 26642,\n\t\"./localcafe.json\": 36391,\n\t\"./localcafeoutlined.json\": 50913,\n\t\"./localcarwash.json\": 35523,\n\t\"./localcarwashoutlined.json\": 54037,\n\t\"./localconveniencestore.json\": 56482,\n\t\"./localconveniencestoreoutlined.json\": 12708,\n\t\"./localdining.json\": 36515,\n\t\"./localdrink.json\": 53708,\n\t\"./localdrinkoutlined.json\": 77646,\n\t\"./localfiredepartment.json\": 88628,\n\t\"./localflorist.json\": 91971,\n\t\"./localfloristoutlined.json\": 94261,\n\t\"./localgasstation.json\": 18381,\n\t\"./localgasstationoutlined.json\": 34247,\n\t\"./localgrocerystore.json\": 66230,\n\t\"./localgrocerystoreoutlined.json\": 84864,\n\t\"./locallaundryservice.json\": 94334,\n\t\"./locallaundryserviceoutlined.json\": 51464,\n\t\"./locallibrary.json\": 35217,\n\t\"./locallibraryoutlined.json\": 98867,\n\t\"./localmall.json\": 42268,\n\t\"./localmalloutlined.json\": 63678,\n\t\"./localmovies.json\": 97307,\n\t\"./localmoviesoutlined.json\": 96589,\n\t\"./localoffer.json\": 6276,\n\t\"./localofferoutlined.json\": 62726,\n\t\"./localparking.json\": 37066,\n\t\"./localpharmacy.json\": 57759,\n\t\"./localpharmacyoutlined.json\": 70585,\n\t\"./localpizza.json\": 45684,\n\t\"./localpizzaoutlined.json\": 91798,\n\t\"./localpolice.json\": 74424,\n\t\"./localpoliceoutlined.json\": 15554,\n\t\"./localshipping.json\": 53168,\n\t\"./localshippingoutlined.json\": 43738,\n\t\"./localtaxi.json\": 41666,\n\t\"./localtaxioutlined.json\": 11236,\n\t\"./locationcity.json\": 69851,\n\t\"./locationoff.json\": 19909,\n\t\"./locationoffoutlined.json\": 43359,\n\t\"./locationon.json\": 13537,\n\t\"./locationonoutlined.json\": 35139,\n\t\"./lock.json\": 77828,\n\t\"./lockclock.json\": 62502,\n\t\"./lockclockoutlined.json\": 77872,\n\t\"./lockopen.json\": 40876,\n\t\"./lockoutlined.json\": 84806,\n\t\"./login.json\": 33272,\n\t\"./logout.json\": 25313,\n\t\"./looks.json\": 81661,\n\t\"./looks3.json\": 51778,\n\t\"./looks3outlined.json\": 87364,\n\t\"./looks4.json\": 57471,\n\t\"./looks4outlined.json\": 66681,\n\t\"./looks5.json\": 20332,\n\t\"./looks5outlined.json\": 68366,\n\t\"./looks6.json\": 54329,\n\t\"./looks6outlined.json\": 15451,\n\t\"./looksone.json\": 10131,\n\t\"./looksoneoutlined.json\": 82021,\n\t\"./lookstwo.json\": 66361,\n\t\"./lookstwooutlined.json\": 49531,\n\t\"./loop.json\": 77533,\n\t\"./loupe.json\": 54550,\n\t\"./lowpriority.json\": 27515,\n\t\"./loyalty.json\": 82407,\n\t\"./loyaltyoutlined.json\": 76321,\n\t\"./lteplusmobiledata.json\": 12216,\n\t\"./luggage.json\": 41197,\n\t\"./luggageoutlined.json\": 80551,\n\t\"./lunchdining.json\": 4956,\n\t\"./lunchdiningoutlined.json\": 90590,\n\t\"./male.json\": 38250,\n\t\"./manageaccounts.json\": 41960,\n\t\"./manageaccountsoutlined.json\": 70258,\n\t\"./managesearch.json\": 5344,\n\t\"./map.json\": 59603,\n\t\"./mapoutlined.json\": 37157,\n\t\"./mapshomework.json\": 57334,\n\t\"./mapshomeworkoutlined.json\": 10656,\n\t\"./mapsugc.json\": 83525,\n\t\"./mapsugcoutlined.json\": 51295,\n\t\"./margin.json\": 78025,\n\t\"./markasunread.json\": 47213,\n\t\"./markasunreadoutlined.json\": 81095,\n\t\"./markchatread.json\": 14900,\n\t\"./markchatreadoutlined.json\": 95382,\n\t\"./markchatunread.json\": 28215,\n\t\"./markchatunreadoutlined.json\": 83889,\n\t\"./markemailread.json\": 9446,\n\t\"./markemailreadoutlined.json\": 24496,\n\t\"./markemailunread.json\": 7037,\n\t\"./markemailunreadoutlined.json\": 43511,\n\t\"./markunread.json\": 53561,\n\t\"./markunreadoutlined.json\": 4603,\n\t\"./masks.json\": 39204,\n\t\"./masksoutlined.json\": 39526,\n\t\"./maximize.json\": 39077,\n\t\"./mediabluetoothoff.json\": 44198,\n\t\"./mediabluetoothon.json\": 50872,\n\t\"./mediation.json\": 93335,\n\t\"./medicalmask.json\": 38958,\n\t\"./medicalservices.json\": 31162,\n\t\"./medicalservicesoutlined.json\": 85628,\n\t\"./medication.json\": 36604,\n\t\"./medicationoutlined.json\": 61150,\n\t\"./meetingroom.json\": 21335,\n\t\"./memory.json\": 84228,\n\t\"./menu.json\": 73884,\n\t\"./menubook.json\": 85213,\n\t\"./menuopen.json\": 26500,\n\t\"./message.json\": 69366,\n\t\"./messageoutlined.json\": 16032,\n\t\"./messenger.json\": 89366,\n\t\"./mic.json\": 92378,\n\t\"./micexternaloff.json\": 78142,\n\t\"./micexternaloffoutlined.json\": 61928,\n\t\"./micexternalon.json\": 49776,\n\t\"./micexternalonoutlined.json\": 5562,\n\t\"./micnone.json\": 54620,\n\t\"./micoff.json\": 19259,\n\t\"./micoffoutlined.json\": 57229,\n\t\"./microbiology.json\": 16864,\n\t\"./microwave.json\": 4088,\n\t\"./microwaveoutlined.json\": 58306,\n\t\"./militarytech.json\": 39072,\n\t\"./militarytechoutlined.json\": 91178,\n\t\"./minimize.json\": 46179,\n\t\"./miscellaneousservices.json\": 46545,\n\t\"./missedvideocall.json\": 25773,\n\t\"./missedvideocalloutlined.json\": 23143,\n\t\"./mixturemed.json\": 54577,\n\t\"./mms.json\": 91822,\n\t\"./mmsoutlined.json\": 11864,\n\t\"./mobiledataoff.json\": 82110,\n\t\"./mobilefriendly.json\": 87250,\n\t\"./mobileoff.json\": 54625,\n\t\"./mobilescreenshare.json\": 20836,\n\t\"./modecomment.json\": 43541,\n\t\"./modecommentoutlined.json\": 86383,\n\t\"./modedual.json\": 65606,\n\t\"./modeltraining.json\": 12506,\n\t\"./modenight.json\": 23222,\n\t\"./modenightoutlined.json\": 72704,\n\t\"./monetizationon.json\": 58995,\n\t\"./monetizationonoutlined.json\": 78821,\n\t\"./money.json\": 56653,\n\t\"./moneyoff.json\": 27834,\n\t\"./monitor.json\": 81987,\n\t\"./monitorheart.json\": 72397,\n\t\"./monitorweight.json\": 11991,\n\t\"./monitorweightoutlined.json\": 25521,\n\t\"./monochromephotos.json\": 27615,\n\t\"./moped.json\": 15796,\n\t\"./mopedoutlined.json\": 62294,\n\t\"./more.json\": 24026,\n\t\"./morehoriz.json\": 7368,\n\t\"./moreoutlined.json\": 41404,\n\t\"./moretime.json\": 87191,\n\t\"./morevert.json\": 18909,\n\t\"./motionphotosauto.json\": 36971,\n\t\"./motionphotosautooutlined.json\": 83357,\n\t\"./motionphotosoff.json\": 9469,\n\t\"./motionphotosoffoutlined.json\": 36535,\n\t\"./mouseoutlined.json\": 3724,\n\t\"./movedown.json\": 68086,\n\t\"./movetoinbox.json\": 82993,\n\t\"./movetoinboxoutlined.json\": 73811,\n\t\"./moveup.json\": 12311,\n\t\"./movie.json\": 96693,\n\t\"./moviefilteroutlined.json\": 53733,\n\t\"./movieoutlined.json\": 2159,\n\t\"./moving.json\": 55329,\n\t\"./movingbeds.json\": 93977,\n\t\"./mp.json\": 34626,\n\t\"./mpoutlined.json\": 79428,\n\t\"./multilinechart.json\": 77342,\n\t\"./multiplestop.json\": 89087,\n\t\"./museum.json\": 22447,\n\t\"./museumoutlined.json\": 65993,\n\t\"./musicnote.json\": 58214,\n\t\"./musicnoteoutlined.json\": 43600,\n\t\"./musicoff.json\": 51315,\n\t\"./musicoffoutlined.json\": 77861,\n\t\"./musicvideo.json\": 78377,\n\t\"./nat.json\": 16878,\n\t\"./nature.json\": 1248,\n\t\"./natureoutlined.json\": 58698,\n\t\"./naturepeople.json\": 15763,\n\t\"./naturepeopleoutlined.json\": 79813,\n\t\"./navigatebefore.json\": 33771,\n\t\"./navigatenext.json\": 43373,\n\t\"./navigation.json\": 44257,\n\t\"./navigationoutlined.json\": 21379,\n\t\"./nearbyerror.json\": 63998,\n\t\"./nearbyoff.json\": 14861,\n\t\"./nearme.json\": 95327,\n\t\"./nearmedisabled.json\": 21519,\n\t\"./nearmedisabledoutlined.json\": 85609,\n\t\"./nearmeoutlined.json\": 82073,\n\t\"./nephrology.json\": 38564,\n\t\"./networkcell.json\": 50951,\n\t\"./networkcheck.json\": 97209,\n\t\"./networklocked.json\": 27105,\n\t\"./networklockedoutlined.json\": 21411,\n\t\"./networkwifi.json\": 31178,\n\t\"./neurology.json\": 10843,\n\t\"./newreleases.json\": 98157,\n\t\"./newreleasesoutlined.json\": 85863,\n\t\"./nextplan.json\": 61965,\n\t\"./nextplanoutlined.json\": 10375,\n\t\"./nextweek.json\": 96466,\n\t\"./nextweekoutlined.json\": 80724,\n\t\"./nfc.json\": 82168,\n\t\"./nightlight.json\": 24705,\n\t\"./nightlightoutlined.json\": 44963,\n\t\"./nightlightround.json\": 81283,\n\t\"./nightlightroundoutlined.json\": 18197,\n\t\"./nightshelter.json\": 47868,\n\t\"./nightshelteroutlined.json\": 6462,\n\t\"./nightsstay.json\": 42477,\n\t\"./nightsstayoutlined.json\": 86375,\n\t\"./ninek.json\": 4208,\n\t\"./ninekoutlined.json\": 92026,\n\t\"./ninekplus.json\": 50112,\n\t\"./ninekplusoutlined.json\": 80586,\n\t\"./ninemp.json\": 48786,\n\t\"./ninempoutlined.json\": 4244,\n\t\"./nineteenmp.json\": 93282,\n\t\"./nineteenmpoutlined.json\": 46180,\n\t\"./noaccounts.json\": 25140,\n\t\"./noaccountsoutlined.json\": 39798,\n\t\"./nobackpack.json\": 250,\n\t\"./nobackpackoutlined.json\": 80668,\n\t\"./nocell.json\": 86244,\n\t\"./nocelloutlined.json\": 32518,\n\t\"./nodrinks.json\": 70003,\n\t\"./nodrinksoutlined.json\": 16741,\n\t\"./noencryption.json\": 98941,\n\t\"./noencryptiongmailerrorred.json\": 70652,\n\t\"./noencryptiongmailerrorredoutlined.json\": 29982,\n\t\"./noencryptionoutlined.json\": 43543,\n\t\"./noflash.json\": 14542,\n\t\"./noflashoutlined.json\": 80824,\n\t\"./nofood.json\": 47588,\n\t\"./nofoodoutlined.json\": 19750,\n\t\"./noluggage.json\": 65808,\n\t\"./noluggageoutlined.json\": 88314,\n\t\"./nomeals.json\": 53984,\n\t\"./nomeetingroom.json\": 32002,\n\t\"./nomeetingroomoutlined.json\": 41604,\n\t\"./nophotography.json\": 63891,\n\t\"./nophotographyoutlined.json\": 20453,\n\t\"./nordicwalking.json\": 20681,\n\t\"./north.json\": 72086,\n\t\"./northeast.json\": 20155,\n\t\"./northwest.json\": 50757,\n\t\"./nosim.json\": 33607,\n\t\"./nosimoutlined.json\": 47329,\n\t\"./nostroller.json\": 67239,\n\t\"./nostrolleroutlined.json\": 31809,\n\t\"./notaccessible.json\": 6406,\n\t\"./note.json\": 68291,\n\t\"./noteaddoutlined.json\": 64412,\n\t\"./notealt.json\": 84834,\n\t\"./notealtoutlined.json\": 49604,\n\t\"./noteoutlined.json\": 73685,\n\t\"./notificationadd.json\": 17711,\n\t\"./notificationaddoutlined.json\": 13193,\n\t\"./notificationimportant.json\": 40486,\n\t\"./notificationimportantoutlined.json\": 77008,\n\t\"./notifications.json\": 88169,\n\t\"./notificationsactive.json\": 31479,\n\t\"./notificationsactiveoutlined.json\": 88241,\n\t\"./notificationsoff.json\": 31014,\n\t\"./notificationsoffoutlined.json\": 92400,\n\t\"./notificationsoutlined.json\": 66059,\n\t\"./notificationspaused.json\": 94891,\n\t\"./notificationspausedoutlined.json\": 53373,\n\t\"./notinterested.json\": 7847,\n\t\"./notlistedlocation.json\": 60370,\n\t\"./notlistedlocationoutlined.json\": 50228,\n\t\"./notransfer.json\": 64139,\n\t\"./notransferoutlined.json\": 7325,\n\t\"./notstarted.json\": 51077,\n\t\"./notstartedoutlined.json\": 61023,\n\t\"./nutrition.json\": 15885,\n\t\"./offers.json\": 676,\n\t\"./offlinebolt.json\": 24489,\n\t\"./offlineboltoutlined.json\": 48075,\n\t\"./offlinepin.json\": 91341,\n\t\"./offlinepinoutlined.json\": 86215,\n\t\"./offlineshare.json\": 10717,\n\t\"./offlineshareoutlined.json\": 76023,\n\t\"./oncology.json\": 97133,\n\t\"./ondemandvideo.json\": 23828,\n\t\"./onek.json\": 82818,\n\t\"./onekk.json\": 23239,\n\t\"./onekkoutlined.json\": 53793,\n\t\"./onekoutlined.json\": 94212,\n\t\"./onekplus.json\": 33246,\n\t\"./onekplusoutlined.json\": 70600,\n\t\"./onlineprediction.json\": 90453,\n\t\"./opacity.json\": 77904,\n\t\"./openinbrowser.json\": 12484,\n\t\"./openinfull.json\": 29181,\n\t\"./openinnew.json\": 6694,\n\t\"./openinnewoff.json\": 31031,\n\t\"./openwith.json\": 3607,\n\t\"./ophthalmology.json\": 49656,\n\t\"./orthopedics.json\": 57365,\n\t\"./otherhouses.json\": 96018,\n\t\"./otherhousesoutlined.json\": 27892,\n\t\"./outbound.json\": 41763,\n\t\"./outboundoutlined.json\": 25877,\n\t\"./outbox.json\": 8886,\n\t\"./outboxoutlined.json\": 69376,\n\t\"./outdoorgrill.json\": 89723,\n\t\"./outdoorgrilloutlined.json\": 67917,\n\t\"./outlet.json\": 49678,\n\t\"./outletoutlined.json\": 57912,\n\t\"./outpatientmed.json\": 63288,\n\t\"./padding.json\": 29952,\n\t\"./pages.json\": 8221,\n\t\"./pagesoutlined.json\": 92215,\n\t\"./pageview.json\": 9573,\n\t\"./pageviewoutlined.json\": 66335,\n\t\"./paid.json\": 54841,\n\t\"./paidoutlined.json\": 86811,\n\t\"./palette.json\": 63854,\n\t\"./paletteoutlined.json\": 72696,\n\t\"./panorama.json\": 67468,\n\t\"./panoramafisheye.json\": 66407,\n\t\"./panoramahorizontal.json\": 6124,\n\t\"./panoramahorizontalselect.json\": 73780,\n\t\"./panoramaoutlined.json\": 77358,\n\t\"./panoramaphotosphere.json\": 38841,\n\t\"./panoramaphotosphereselect.json\": 9633,\n\t\"./panoramavertical.json\": 27674,\n\t\"./panoramaverticalselect.json\": 24962,\n\t\"./panoramawideangle.json\": 82846,\n\t\"./panoramawideangleselect.json\": 14998,\n\t\"./pantool.json\": 64692,\n\t\"./pantooloutlined.json\": 47510,\n\t\"./paragliding.json\": 44985,\n\t\"./paraglidingoutlined.json\": 39419,\n\t\"./park.json\": 40487,\n\t\"./parkoutlined.json\": 56897,\n\t\"./partymode.json\": 93766,\n\t\"./partymodeoutlined.json\": 17008,\n\t\"./password.json\": 62542,\n\t\"./pattern.json\": 87155,\n\t\"./pause.json\": 87283,\n\t\"./pausecircle.json\": 34395,\n\t\"./pausecircleoutlined.json\": 95437,\n\t\"./pausepresentation.json\": 80539,\n\t\"./payment.json\": 18567,\n\t\"./payments.json\": 98564,\n\t\"./paymentsoutlined.json\": 47462,\n\t\"./pedalbike.json\": 42904,\n\t\"./pediatrics.json\": 47681,\n\t\"./pending.json\": 94038,\n\t\"./pendingactions.json\": 28045,\n\t\"./pendingoutlined.json\": 74944,\n\t\"./people.json\": 81336,\n\t\"./peoplealt.json\": 34987,\n\t\"./peoplealtoutlined.json\": 56765,\n\t\"./peopleoutline.json\": 87986,\n\t\"./peopleoutlined.json\": 8674,\n\t\"./permcameramic.json\": 34757,\n\t\"./permcameramicoutlined.json\": 74207,\n\t\"./permcontactcalendar.json\": 65093,\n\t\"./permcontactcalendaroutlined.json\": 2623,\n\t\"./permdatasetting.json\": 27971,\n\t\"./permdatasettingoutlined.json\": 51765,\n\t\"./permdeviceinformation.json\": 91287,\n\t\"./permdeviceinformationoutlined.json\": 26353,\n\t\"./permmedia.json\": 9707,\n\t\"./permmediaoutlined.json\": 39805,\n\t\"./permphonemsg.json\": 6440,\n\t\"./permphonemsgoutlined.json\": 12722,\n\t\"./permscanwifi.json\": 66609,\n\t\"./permscanwifioutlined.json\": 89235,\n\t\"./person.json\": 76274,\n\t\"./personadd.json\": 25721,\n\t\"./personaddalt1.json\": 21735,\n\t\"./personaddalt1outlined.json\": 17153,\n\t\"./personadddisabled.json\": 63225,\n\t\"./personadddisabledoutlined.json\": 923,\n\t\"./personaddoutlined.json\": 16027,\n\t\"./personalvideo.json\": 59874,\n\t\"./personoff.json\": 86579,\n\t\"./personoffoutlined.json\": 24165,\n\t\"./personoutlined.json\": 26676,\n\t\"./personpin.json\": 63289,\n\t\"./personpincircle.json\": 74885,\n\t\"./personpincircleoutlined.json\": 71967,\n\t\"./personpinoutlined.json\": 94011,\n\t\"./personraisedhand.json\": 82759,\n\t\"./personremove.json\": 47806,\n\t\"./personremoveoutlined.json\": 22664,\n\t\"./personsearch.json\": 32154,\n\t\"./personsearchoutlined.json\": 34044,\n\t\"./pestcontrol.json\": 17356,\n\t\"./pestcontroloutlined.json\": 12238,\n\t\"./pestcontrolrodent.json\": 77650,\n\t\"./pestcontrolrodentoutlined.json\": 31700,\n\t\"./pets.json\": 43789,\n\t\"./phone.json\": 94661,\n\t\"./phoneandroid.json\": 35720,\n\t\"./phoneandroidoutlined.json\": 80178,\n\t\"./phonebluetoothspeaker.json\": 37010,\n\t\"./phonebluetoothspeakeroutlined.json\": 40692,\n\t\"./phonecallback.json\": 54598,\n\t\"./phonecallbackoutlined.json\": 49584,\n\t\"./phonedisabled.json\": 57170,\n\t\"./phonedisabledoutlined.json\": 79583,\n\t\"./phoneenabled.json\": 36798,\n\t\"./phoneenabledoutlined.json\": 97288,\n\t\"./phoneforwarded.json\": 17807,\n\t\"./phoneforwardedoutlined.json\": 71369,\n\t\"./phoneintalk.json\": 20716,\n\t\"./phoneintalkoutlined.json\": 91950,\n\t\"./phoneiphone.json\": 31492,\n\t\"./phonelink.json\": 15649,\n\t\"./phonelinkerase.json\": 35625,\n\t\"./phonelinklock.json\": 16614,\n\t\"./phonelinkoff.json\": 65310,\n\t\"./phonelinkring.json\": 6091,\n\t\"./phonelinksetup.json\": 49762,\n\t\"./phonelinksetupoutlined.json\": 35876,\n\t\"./phonelocked.json\": 51655,\n\t\"./phonelockedoutlined.json\": 12065,\n\t\"./phonemissed.json\": 12852,\n\t\"./phonemissedoutlined.json\": 8310,\n\t\"./phoneoutlined.json\": 59967,\n\t\"./phonepaused.json\": 23439,\n\t\"./phonepausedoutlined.json\": 34505,\n\t\"./photo.json\": 14793,\n\t\"./photoalbum.json\": 8828,\n\t\"./photoalbumoutlined.json\": 36094,\n\t\"./photocamera.json\": 52210,\n\t\"./photocameraback.json\": 93569,\n\t\"./photocamerabackoutlined.json\": 18499,\n\t\"./photocamerafront.json\": 37005,\n\t\"./photocamerafrontoutlined.json\": 55335,\n\t\"./photocameraoutlined.json\": 2804,\n\t\"./photofilter.json\": 37095,\n\t\"./photolibrary.json\": 66936,\n\t\"./photolibraryoutlined.json\": 91842,\n\t\"./photooutlined.json\": 16587,\n\t\"./photosizeselectactual.json\": 60590,\n\t\"./photosizeselectactualoutlined.json\": 36504,\n\t\"./photosizeselectlarge.json\": 39123,\n\t\"./photosizeselectsmall.json\": 56763,\n\t\"./php.json\": 32181,\n\t\"./pilloff.json\": 2457,\n\t\"./pinch.json\": 61229,\n\t\"./pinterest.json\": 44695,\n\t\"./pivottablechart.json\": 13849,\n\t\"./place.json\": 30854,\n\t\"./placeoutlined.json\": 38512,\n\t\"./plagiarism.json\": 65596,\n\t\"./plagiarismoutlined.json\": 62910,\n\t\"./playarrow.json\": 82438,\n\t\"./playarrowoutlined.json\": 38224,\n\t\"./playcircle.json\": 83025,\n\t\"./playcircleoutlined.json\": 54483,\n\t\"./playdisabled.json\": 4245,\n\t\"./playdisabledoutlined.json\": 12079,\n\t\"./playforwork.json\": 56781,\n\t\"./playlesson.json\": 79513,\n\t\"./playlessonoutlined.json\": 88155,\n\t\"./playlistadd.json\": 11676,\n\t\"./playlistaddcheck.json\": 43828,\n\t\"./playlistplay.json\": 38675,\n\t\"./plumbing.json\": 61343,\n\t\"./plusone.json\": 74785,\n\t\"./podcasts.json\": 43034,\n\t\"./pointofsale.json\": 23993,\n\t\"./policy.json\": 48785,\n\t\"./policyoutlined.json\": 88851,\n\t\"./poll.json\": 20094,\n\t\"./polloutlined.json\": 72008,\n\t\"./pool.json\": 93597,\n\t\"./portablewifioff.json\": 31906,\n\t\"./portrait.json\": 72356,\n\t\"./portraitoutlined.json\": 18054,\n\t\"./postadd.json\": 82900,\n\t\"./power.json\": 69756,\n\t\"./powerinput.json\": 75608,\n\t\"./poweroff.json\": 56829,\n\t\"./poweroffoutlined.json\": 84503,\n\t\"./poweroutlined.json\": 39358,\n\t\"./powersettingsnew.json\": 65353,\n\t\"./precisionmanufacturing.json\": 2137,\n\t\"./precisionmanufacturingoutlined.json\": 84859,\n\t\"./pregnantwoman.json\": 38088,\n\t\"./presenttoall.json\": 15046,\n\t\"./preview.json\": 14025,\n\t\"./previewoutlined.json\": 8555,\n\t\"./pricechange.json\": 18364,\n\t\"./pricechangoutlined.json\": 9079,\n\t\"./pricecheck.json\": 49836,\n\t\"./print.json\": 10110,\n\t\"./printdisabled.json\": 15510,\n\t\"./printdisabledoutlined.json\": 32576,\n\t\"./printoutlined.json\": 20424,\n\t\"./priorityhigh.json\": 54743,\n\t\"./privacytip.json\": 50694,\n\t\"./privacytipoutlined.json\": 58064,\n\t\"./procedure.json\": 64104,\n\t\"./productionquantitylimits.json\": 72621,\n\t\"./psychiatry.json\": 44921,\n\t\"./psychology.json\": 82842,\n\t\"./psychologyoutlined.json\": 68412,\n\t\"./public.json\": 60938,\n\t\"./publicoff.json\": 14027,\n\t\"./publish.json\": 92510,\n\t\"./publishedwithchanges.json\": 50452,\n\t\"./publishoutlined.json\": 60456,\n\t\"./pulmonology.json\": 59014,\n\t\"./pushpin.json\": 73442,\n\t\"./pushpinoutlined.json\": 84420,\n\t\"./qrcode.json\": 73237,\n\t\"./qrcode2.json\": 20405,\n\t\"./qrcodescanner.json\": 29957,\n\t\"./querystats.json\": 92144,\n\t\"./questionanswer.json\": 61621,\n\t\"./questionansweroutlined.json\": 91983,\n\t\"./queue.json\": 32366,\n\t\"./queuemusic.json\": 16821,\n\t\"./queueoutlined.json\": 38264,\n\t\"./queueplaynext.json\": 77273,\n\t\"./quickreply.json\": 10518,\n\t\"./quickreplyoutlined.json\": 51936,\n\t\"./quiz.json\": 53170,\n\t\"./quizoutlined.json\": 35316,\n\t\"./radar.json\": 68097,\n\t\"./radio.json\": 44378,\n\t\"./radiobuttonchecked.json\": 9071,\n\t\"./radiobuttonunchecked.json\": 35010,\n\t\"./radiology.json\": 53735,\n\t\"./railwayalert.json\": 2816,\n\t\"./railwayalertoutlined.json\": 6442,\n\t\"./ramendining.json\": 50911,\n\t\"./ramendiningoutlined.json\": 18617,\n\t\"./ratereview.json\": 5217,\n\t\"./ratereviewoutlined.json\": 7043,\n\t\"./raven.json\": 10243,\n\t\"./rawoff.json\": 72800,\n\t\"./rawon.json\": 86458,\n\t\"./readmore.json\": 11982,\n\t\"./receipt.json\": 32209,\n\t\"./receiptlong.json\": 25235,\n\t\"./receiptlongoutlined.json\": 54789,\n\t\"./receiptoutlined.json\": 96563,\n\t\"./recentactors.json\": 76402,\n\t\"./recentactorsoutlined.json\": 46676,\n\t\"./recommend.json\": 29015,\n\t\"./recommendoutlined.json\": 14897,\n\t\"./recordvoiceover.json\": 94082,\n\t\"./recordvoiceoveroutlined.json\": 59236,\n\t\"./reddit.json\": 50471,\n\t\"./redeem.json\": 80727,\n\t\"./redo.json\": 90183,\n\t\"./reducecapacity.json\": 27349,\n\t\"./refresh.json\": 58578,\n\t\"./rememberme.json\": 49166,\n\t\"./remembermeoutlined.json\": 20152,\n\t\"./remove.json\": 33423,\n\t\"./removecircle.json\": 92311,\n\t\"./removecircleoutlined.json\": 95601,\n\t\"./removedone.json\": 17955,\n\t\"./removedoneoutlined.json\": 6677,\n\t\"./removefromqueue.json\": 97934,\n\t\"./removemoderator.json\": 83406,\n\t\"./removemoderatoroutlined.json\": 53016,\n\t\"./removeredeye.json\": 46767,\n\t\"./removeredeyeoutlined.json\": 55945,\n\t\"./removeshoppingcart.json\": 19997,\n\t\"./removeshoppingcartoutlined.json\": 49540,\n\t\"./repartition.json\": 96560,\n\t\"./repeat.json\": 44548,\n\t\"./repeaton.json\": 35105,\n\t\"./repeatone.json\": 44304,\n\t\"./repeatoneon.json\": 14781,\n\t\"./replay.json\": 99124,\n\t\"./replay10.json\": 37105,\n\t\"./replay30.json\": 37935,\n\t\"./replay5.json\": 6459,\n\t\"./replaycirclefilled.json\": 57024,\n\t\"./reply.json\": 56249,\n\t\"./replyall.json\": 46764,\n\t\"./report.json\": 45345,\n\t\"./reportoff.json\": 4126,\n\t\"./reportoffoutlined.json\": 23720,\n\t\"./reportoutlined.json\": 45411,\n\t\"./reportproblem.json\": 31084,\n\t\"./reportproblemoutlined.json\": 16686,\n\t\"./requestpage.json\": 79831,\n\t\"./requestpageoutlined.json\": 8561,\n\t\"./requestquote.json\": 47928,\n\t\"./requestquoteoutlined.json\": 26786,\n\t\"./resettv.json\": 60916,\n\t\"./resettvoutlined.json\": 40598,\n\t\"./respiratoryrate.json\": 73571,\n\t\"./restartalt.json\": 8901,\n\t\"./restaurant.json\": 15804,\n\t\"./restaurantmenu.json\": 32331,\n\t\"./restore.json\": 50747,\n\t\"./restorefromtrash.json\": 21291,\n\t\"./restorepage.json\": 14864,\n\t\"./restorepageoutlined.json\": 7450,\n\t\"./rheumatology.json\": 74301,\n\t\"./ricebowl.json\": 24422,\n\t\"./ricebowloutlined.json\": 18307,\n\t\"./ringvolume.json\": 9591,\n\t\"./ringvolumeoutlined.json\": 49553,\n\t\"./rmobiledata.json\": 48409,\n\t\"./roofing.json\": 48859,\n\t\"./room.json\": 58724,\n\t\"./roomoutlined.json\": 50982,\n\t\"./roompreferences.json\": 64642,\n\t\"./roompreferencesoutlined.json\": 68804,\n\t\"./roomservice.json\": 26039,\n\t\"./roomserviceoutlined.json\": 62737,\n\t\"./rotate90degreesccw.json\": 3321,\n\t\"./rotateleft.json\": 26565,\n\t\"./rotateright.json\": 20526,\n\t\"./roundedcorner.json\": 99369,\n\t\"./router.json\": 57298,\n\t\"./routeroutlined.json\": 17492,\n\t\"./rowing.json\": 34111,\n\t\"./rssfeed.json\": 92853,\n\t\"./rsvp.json\": 20266,\n\t\"./rtt.json\": 99563,\n\t\"./rule.json\": 32577,\n\t\"./rulefolder.json\": 23073,\n\t\"./rulefolderoutlined.json\": 84451,\n\t\"./runcircle.json\": 50400,\n\t\"./runcircleoutlined.json\": 10058,\n\t\"./runningwitherrors.json\": 11845,\n\t\"./rvhookup.json\": 81633,\n\t\"./safetydivider.json\": 97618,\n\t\"./sailing.json\": 14414,\n\t\"./sailingoutlined.json\": 35544,\n\t\"./salinity.json\": 97178,\n\t\"./sanitizer.json\": 64614,\n\t\"./sanitizeroutlined.json\": 91248,\n\t\"./satellite.json\": 93672,\n\t\"./satelliteoutlined.json\": 7794,\n\t\"./save.json\": 33754,\n\t\"./savealt.json\": 56009,\n\t\"./savedsearch.json\": 90898,\n\t\"./saveoutlined.json\": 93372,\n\t\"./savings.json\": 59722,\n\t\"./savingsoutlined.json\": 87564,\n\t\"./scanner.json\": 70083,\n\t\"./scanneroutlined.json\": 12117,\n\t\"./scatterplot.json\": 99984,\n\t\"./scatterplotoutlined.json\": 5882,\n\t\"./schedule.json\": 12918,\n\t\"./schedulesend.json\": 22632,\n\t\"./schedulesendoutlined.json\": 46706,\n\t\"./schema.json\": 4044,\n\t\"./schemaoutlined.json\": 61486,\n\t\"./school.json\": 81111,\n\t\"./schooloutlined.json\": 11697,\n\t\"./science.json\": 60471,\n\t\"./scienceoutlined.json\": 74929,\n\t\"./score.json\": 28319,\n\t\"./scoreoutlined.json\": 71097,\n\t\"./screenlocklandscape.json\": 74825,\n\t\"./screenlockportrait.json\": 95483,\n\t\"./screenlockrotation.json\": 80810,\n\t\"./screenrotation.json\": 31413,\n\t\"./screensearchdesktop.json\": 87689,\n\t\"./screensearchdesktopoutlined.json\": 92363,\n\t\"./screenshare.json\": 16621,\n\t\"./screenshareoutlined.json\": 64124,\n\t\"./screenshot.json\": 81727,\n\t\"./screenshotoutlined.json\": 94393,\n\t\"./sd.json\": 71628,\n\t\"./sdcard.json\": 48470,\n\t\"./sdcardalert.json\": 43696,\n\t\"./sdcardalertoutlined.json\": 34874,\n\t\"./sdcardoutlined.json\": 46048,\n\t\"./sdoutlined.json\": 46670,\n\t\"./sdstorage.json\": 95361,\n\t\"./sdstorageoutlined.json\": 12163,\n\t\"./search.json\": 81219,\n\t\"./searchalt.json\": 65890,\n\t\"./searchoff.json\": 78208,\n\t\"./security.json\": 14089,\n\t\"./securityupdate.json\": 62196,\n\t\"./securityupdategood.json\": 10613,\n\t\"./securityupdategoodoutlined.json\": 65679,\n\t\"./securityupdateoutlined.json\": 52086,\n\t\"./securityupdatewarning.json\": 24792,\n\t\"./securityupdatewarningoutlined.json\": 20354,\n\t\"./segment.json\": 69676,\n\t\"./selectall.json\": 69770,\n\t\"./selfimprovement.json\": 85775,\n\t\"./sell.json\": 85695,\n\t\"./selloutlined.json\": 63321,\n\t\"./send.json\": 70809,\n\t\"./sendandarchive.json\": 85956,\n\t\"./sendandarchiveoutlined.json\": 84582,\n\t\"./sendoutlined.json\": 75547,\n\t\"./sendtimeextension.json\": 86437,\n\t\"./sendtomobile.json\": 7698,\n\t\"./sendtomobileoutlined.json\": 61076,\n\t\"./sensordoor.json\": 52981,\n\t\"./sensordooroutlined.json\": 83439,\n\t\"./sensors.json\": 75118,\n\t\"./sensorsoff.json\": 14175,\n\t\"./sensorwindow.json\": 52097,\n\t\"./sensorwindowoutlined.json\": 98499,\n\t\"./sentimentdissatisfied.json\": 94408,\n\t\"./sentimentdissatisfiedoutlined.json\": 71922,\n\t\"./sentimentneutral.json\": 85935,\n\t\"./sentimentneutraloutlined.json\": 53046,\n\t\"./sentimentsatisfied.json\": 95684,\n\t\"./sentimentsatisfiedoutlined.json\": 53766,\n\t\"./sentimentverydissatisfied.json\": 15356,\n\t\"./sentimentverydissatisfiedoutlined.json\": 6590,\n\t\"./sentimentverysatisfied.json\": 20776,\n\t\"./sentimentverysatisfiedoutlined.json\": 61426,\n\t\"./setmeal.json\": 1578,\n\t\"./setmealoutlined.json\": 87692,\n\t\"./settings.json\": 4354,\n\t\"./settingsaccessibility.json\": 62426,\n\t\"./settingsapplications.json\": 73641,\n\t\"./settingsapplicationsoutlined.json\": 60043,\n\t\"./settingsbackuprestore.json\": 96310,\n\t\"./settingsbrightness.json\": 57945,\n\t\"./settingscell.json\": 15986,\n\t\"./settingscelloutlined.json\": 85588,\n\t\"./settingsethernet.json\": 34789,\n\t\"./settingsinputantenna.json\": 43873,\n\t\"./settingsinputcomponent.json\": 3533,\n\t\"./settingsinputcomponentoutlined.json\": 66535,\n\t\"./settingsinputhdmi.json\": 57976,\n\t\"./settingsinputhdmioutlined.json\": 50594,\n\t\"./settingsinputsvideo.json\": 76882,\n\t\"./settingsoutlined.json\": 57444,\n\t\"./settingsoverscan.json\": 24057,\n\t\"./settingsphone.json\": 19810,\n\t\"./settingsphoneoutlined.json\": 30276,\n\t\"./settingspower.json\": 26031,\n\t\"./settingsremote.json\": 22356,\n\t\"./settingsremoteoutlined.json\": 3990,\n\t\"./settingssuggest.json\": 3268,\n\t\"./settingssuggestoutlined.json\": 92678,\n\t\"./settingssystemdaydream.json\": 48790,\n\t\"./settingssystemdaydreamoutlined.json\": 34336,\n\t\"./settingsvoice.json\": 42408,\n\t\"./settingsvoiceoutlined.json\": 50226,\n\t\"./sevenk.json\": 88689,\n\t\"./sevenkoutlined.json\": 46227,\n\t\"./sevenkplus.json\": 20865,\n\t\"./sevenkplusoutlined.json\": 97763,\n\t\"./sevenmp.json\": 27853,\n\t\"./sevenmpoutlined.json\": 27527,\n\t\"./seventeenmp.json\": 7081,\n\t\"./seventeenmpoutlined.json\": 15147,\n\t\"./share.json\": 53166,\n\t\"./sharelocation.json\": 64562,\n\t\"./shareoutlined.json\": 32184,\n\t\"./shield.json\": 56470,\n\t\"./shieldoutlined.json\": 8320,\n\t\"./shop.json\": 46303,\n\t\"./shop2.json\": 24351,\n\t\"./shop2outlined.json\": 69945,\n\t\"./shopoutlined.json\": 19961,\n\t\"./shoppingbag.json\": 32923,\n\t\"./shoppingbagoutlined.json\": 94765,\n\t\"./shoppingbasket.json\": 21233,\n\t\"./shoppingbasketoutlined.json\": 74803,\n\t\"./shoppingcart.json\": 61425,\n\t\"./shoppingcartoutlined.json\": 58547,\n\t\"./shortcut.json\": 43925,\n\t\"./shorttext.json\": 39644,\n\t\"./showchart.json\": 11790,\n\t\"./shower.json\": 92013,\n\t\"./showeroutlined.json\": 1287,\n\t\"./shuffle.json\": 46556,\n\t\"./shuffleon.json\": 30105,\n\t\"./shutterspeed.json\": 34183,\n\t\"./sick.json\": 87709,\n\t\"./sickoutlined.json\": 13975,\n\t\"./signalcellular0bar.json\": 1616,\n\t\"./signalcellular1bar.json\": 25901,\n\t\"./signalcellular2bar.json\": 64446,\n\t\"./signalcellular3bar.json\": 35971,\n\t\"./signalcellular4bar.json\": 36348,\n\t\"./signalcellularalt.json\": 80796,\n\t\"./signalcellularconnectednointernet.json\": 70398,\n\t\"./signalcellularconnectednointernetoutlined.json\": 89384,\n\t\"./signalcellularnodata.json\": 39726,\n\t\"./signalcellularnosim.json\": 40037,\n\t\"./signalcellularnosimoutlined.json\": 82015,\n\t\"./signalcellularnull.json\": 13820,\n\t\"./signalcellularoff.json\": 8990,\n\t\"./signalwifi0bar.json\": 80475,\n\t\"./signalwifi1bar.json\": 50326,\n\t\"./signalwifi1barlock.json\": 63769,\n\t\"./signalwifi2bar.json\": 11621,\n\t\"./signalwifi2barlock.json\": 41306,\n\t\"./signalwifi3bar.json\": 88552,\n\t\"./signalwifi3barlock.json\": 59927,\n\t\"./signalwifi4bar.json\": 27159,\n\t\"./signalwifi4barlock.json\": 61768,\n\t\"./signalwifibad.json\": 55717,\n\t\"./signalwifioff.json\": 45899,\n\t\"./signalwifistatusbar4bar.json\": 20828,\n\t\"./signalwifistatusbarconnectednointernet.json\": 41150,\n\t\"./signalwifistatusbarnull.json\": 38108,\n\t\"./simcard.json\": 43136,\n\t\"./simcardalert.json\": 31594,\n\t\"./simcardalertoutlined.json\": 92492,\n\t\"./simcarddownload.json\": 65384,\n\t\"./simcarddownloadoutlined.json\": 1874,\n\t\"./simcardoutlined.json\": 24298,\n\t\"./singlebed.json\": 79398,\n\t\"./sip.json\": 9005,\n\t\"./sipoutlined.json\": 11143,\n\t\"./sixk.json\": 68146,\n\t\"./sixkoutlined.json\": 51188,\n\t\"./sixkplus.json\": 8590,\n\t\"./sixkplusoutlined.json\": 19640,\n\t\"./sixmp.json\": 6412,\n\t\"./sixmpoutlined.json\": 72974,\n\t\"./sixteenmp.json\": 16088,\n\t\"./sixteenmpoutlined.json\": 4514,\n\t\"./sixtyfps.json\": 69097,\n\t\"./sixtyfpsselect.json\": 57073,\n\t\"./skateboarding.json\": 44463,\n\t\"./skeleton.json\": 40548,\n\t\"./skipnext.json\": 43717,\n\t\"./skipnextoutlined.json\": 21375,\n\t\"./skipprevious.json\": 60057,\n\t\"./skippreviousoutlined.json\": 45179,\n\t\"./sledding.json\": 97969,\n\t\"./slideshow.json\": 29273,\n\t\"./slowmotionvideo.json\": 42675,\n\t\"./smartbutton.json\": 53256,\n\t\"./smartdisplay.json\": 69430,\n\t\"./smartdisplayoutlined.json\": 18848,\n\t\"./smartphone.json\": 34384,\n\t\"./smartscreen.json\": 38840,\n\t\"./smartscreenoutlined.json\": 65346,\n\t\"./smarttoy.json\": 31340,\n\t\"./smarttoyoutlined.json\": 63534,\n\t\"./smokefree.json\": 6438,\n\t\"./smokingrooms.json\": 89957,\n\t\"./sms.json\": 15764,\n\t\"./smsfailed.json\": 3045,\n\t\"./smsfailedoutlined.json\": 84511,\n\t\"./smsoutlined.json\": 61750,\n\t\"./snapchat.json\": 35737,\n\t\"./snapchatoutlined.json\": 40456,\n\t\"./snippetfolder.json\": 99852,\n\t\"./snippetfolderoutlined.json\": 51438,\n\t\"./snooze.json\": 31861,\n\t\"./snowboarding.json\": 51320,\n\t\"./snowmobile.json\": 83758,\n\t\"./snowmobileoutlined.json\": 50328,\n\t\"./snowshoeing.json\": 74265,\n\t\"./soap.json\": 50412,\n\t\"./soapoutlined.json\": 20110,\n\t\"./socialdistance.json\": 40191,\n\t\"./sort.json\": 55211,\n\t\"./sortbyalpha.json\": 23946,\n\t\"./source.json\": 75946,\n\t\"./south.json\": 42316,\n\t\"./southeast.json\": 41877,\n\t\"./southwest.json\": 59275,\n\t\"./spa.json\": 30203,\n\t\"./spacebar.json\": 7720,\n\t\"./spaoutlined.json\": 65069,\n\t\"./speaker.json\": 98008,\n\t\"./speakergroup.json\": 30299,\n\t\"./speakergroupoutlined.json\": 40365,\n\t\"./speakernotes.json\": 55145,\n\t\"./speakernotesoff.json\": 5510,\n\t\"./speakernotesoffoutlined.json\": 94480,\n\t\"./speakernotesoutlined.json\": 70187,\n\t\"./speakeroutlined.json\": 16578,\n\t\"./speakerphone.json\": 57500,\n\t\"./speed.json\": 91498,\n\t\"./spellcheck.json\": 74965,\n\t\"./splitscreen.json\": 42617,\n\t\"./sports.json\": 99064,\n\t\"./sportsbaseball.json\": 80044,\n\t\"./sportsbaseballoutlined.json\": 97262,\n\t\"./sportsbasketball.json\": 15651,\n\t\"./sportsbasketballoutlined.json\": 24149,\n\t\"./sportscricket.json\": 5719,\n\t\"./sportscricketoutlined.json\": 99633,\n\t\"./sportsesports.json\": 78868,\n\t\"./sportsesportsoutlined.json\": 72694,\n\t\"./sportsfootball.json\": 4453,\n\t\"./sportsfootballoutlined.json\": 61631,\n\t\"./sportsgolf.json\": 19928,\n\t\"./sportshandball.json\": 45336,\n\t\"./sportshockey.json\": 11717,\n\t\"./sportskabaddi.json\": 9036,\n\t\"./sportsmma.json\": 60569,\n\t\"./sportsmmaoutlined.json\": 96891,\n\t\"./sportsmotorsports.json\": 6186,\n\t\"./sportsmotorsportsoutlined.json\": 31788,\n\t\"./sportsrugby.json\": 63683,\n\t\"./sportsrugbyoutlined.json\": 5749,\n\t\"./sportsscore.json\": 62326,\n\t\"./sportssoccer.json\": 35815,\n\t\"./sportstennis.json\": 31959,\n\t\"./sportsvolleyball.json\": 23508,\n\t\"./sportsvolleyballoutlined.json\": 18102,\n\t\"./squarefoot.json\": 81968,\n\t\"./squarefootoutlined.json\": 70106,\n\t\"./stackedbarchart.json\": 85023,\n\t\"./stackedlinechart.json\": 31310,\n\t\"./stairs.json\": 9405,\n\t\"./stairsoutlined.json\": 8951,\n\t\"./star.json\": 12111,\n\t\"./starborder.json\": 76253,\n\t\"./starborderpurple500.json\": 59990,\n\t\"./starborderpurple500outlined.json\": 71488,\n\t\"./starhalf.json\": 48046,\n\t\"./starpurple500.json\": 52480,\n\t\"./starrate.json\": 46601,\n\t\"./starrateoutlined.json\": 15499,\n\t\"./stars.json\": 12828,\n\t\"./starsoutlined.json\": 66750,\n\t\"./staycurrentlandscape.json\": 99712,\n\t\"./staycurrentportrait.json\": 43276,\n\t\"./stethoscope.json\": 20308,\n\t\"./stethoscopearrow.json\": 13729,\n\t\"./stethoscopecheck.json\": 33244,\n\t\"./stickynote2.json\": 29658,\n\t\"./stickynote2outlined.json\": 9052,\n\t\"./stop.json\": 14587,\n\t\"./stopcircle.json\": 28291,\n\t\"./stopcircleoutlined.json\": 76085,\n\t\"./stopoutlined.json\": 37613,\n\t\"./stopscreenshare.json\": 26930,\n\t\"./stopscreenshareoutlined.json\": 88116,\n\t\"./storage.json\": 64440,\n\t\"./store.json\": 64292,\n\t\"./storefront.json\": 33219,\n\t\"./storeoutlined.json\": 86374,\n\t\"./storm.json\": 44908,\n\t\"./straighten.json\": 39018,\n\t\"./stream.json\": 7603,\n\t\"./streetview.json\": 66705,\n\t\"./strikethroughs.json\": 57271,\n\t\"./stroller.json\": 72020,\n\t\"./strolleroutlined.json\": 66550,\n\t\"./style.json\": 23660,\n\t\"./styleoutlined.json\": 42830,\n\t\"./subdirectoryarrowleft.json\": 53838,\n\t\"./subdirectoryarrowright.json\": 1943,\n\t\"./subject.json\": 78405,\n\t\"./subscript.json\": 11064,\n\t\"./subscriptions.json\": 70895,\n\t\"./subscriptionsoutlined.json\": 11945,\n\t\"./subtitles.json\": 39772,\n\t\"./subtitlesoff.json\": 16317,\n\t\"./subtitlesoffoutlined.json\": 74327,\n\t\"./subtitlesoutlined.json\": 70782,\n\t\"./subway.json\": 39002,\n\t\"./subwayoutlined.json\": 61468,\n\t\"./summarize.json\": 72808,\n\t\"./summarizeoutlined.json\": 18674,\n\t\"./superscript.json\": 12137,\n\t\"./supervisedusercircle.json\": 46938,\n\t\"./supervisedusercircleoutlined.json\": 64060,\n\t\"./supervisoraccount.json\": 2948,\n\t\"./supervisoraccountoutlined.json\": 3366,\n\t\"./support.json\": 72970,\n\t\"./supportagent.json\": 35171,\n\t\"./surfing.json\": 29721,\n\t\"./surgical.json\": 51897,\n\t\"./surroundsound.json\": 10716,\n\t\"./surroundsoundoutlined.json\": 51166,\n\t\"./swapcalls.json\": 58705,\n\t\"./swaphoriz.json\": 87218,\n\t\"./swaphorizontalcircle.json\": 24912,\n\t\"./swaphorizontalcircleoutlined.json\": 23706,\n\t\"./swapvert.json\": 70679,\n\t\"./swapverticalcircle.json\": 19562,\n\t\"./swapverticalcircleoutlined.json\": 1388,\n\t\"./swipe.json\": 9699,\n\t\"./swipeoutlined.json\": 36053,\n\t\"./switchaccount.json\": 24346,\n\t\"./switchaccountoutlined.json\": 68476,\n\t\"./switchcamera.json\": 96924,\n\t\"./switchcameraoutlined.json\": 57630,\n\t\"./switchleft.json\": 64366,\n\t\"./switchright.json\": 85623,\n\t\"./switchvideo.json\": 70930,\n\t\"./switchvideooutlined.json\": 50516,\n\t\"./sync.json\": 30084,\n\t\"./syncalt.json\": 15935,\n\t\"./syncdisabled.json\": 2732,\n\t\"./syncproblem.json\": 90851,\n\t\"./syringe.json\": 30024,\n\t\"./systemsecurityupdate.json\": 45585,\n\t\"./systemsecurityupdategood.json\": 47464,\n\t\"./systemsecurityupdategoodoutlined.json\": 39090,\n\t\"./systemsecurityupdateoutlined.json\": 61683,\n\t\"./systemsecurityupdatewarning.json\": 36431,\n\t\"./systemsecurityupdatewarningoutlined.json\": 77609,\n\t\"./systemupdate.json\": 24603,\n\t\"./systemupdatealt.json\": 7162,\n\t\"./tab.json\": 42478,\n\t\"./tablechart.json\": 10811,\n\t\"./tablechartoutlined.json\": 73965,\n\t\"./tablelamp.json\": 28315,\n\t\"./tablerows.json\": 7768,\n\t\"./tablerowsoutlined.json\": 17154,\n\t\"./tablet.json\": 55795,\n\t\"./tabletandroid.json\": 58294,\n\t\"./tabletmac.json\": 41714,\n\t\"./tableview.json\": 76016,\n\t\"./tabunselected.json\": 69640,\n\t\"./tag.json\": 46365,\n\t\"./takeoutdining.json\": 73837,\n\t\"./takeoutdiningoutlined.json\": 45575,\n\t\"./tapandplay.json\": 69379,\n\t\"./tapas.json\": 58924,\n\t\"./tapasoutlined.json\": 81710,\n\t\"./task.json\": 74702,\n\t\"./taskalt.json\": 8197,\n\t\"./taskoutlined.json\": 52280,\n\t\"./taxialert.json\": 88795,\n\t\"./taxialertoutlined.json\": 5837,\n\t\"./teams.json\": 39691,\n\t\"./telegram.json\": 88140,\n\t\"./telegramoutlined.json\": 61966,\n\t\"./tenmp.json\": 45807,\n\t\"./tenmpoutlined.json\": 37321,\n\t\"./terrain.json\": 28932,\n\t\"./terrainoutlined.json\": 15302,\n\t\"./textfields.json\": 70845,\n\t\"./textformat.json\": 97655,\n\t\"./textrotateup.json\": 77490,\n\t\"./textrotatevertical.json\": 66713,\n\t\"./textrotationangledown.json\": 36653,\n\t\"./textrotationangleup.json\": 71612,\n\t\"./textrotationdown.json\": 67982,\n\t\"./textrotationnone.json\": 48072,\n\t\"./textsms.json\": 32477,\n\t\"./textsmsoutlined.json\": 23607,\n\t\"./textsnippet.json\": 85381,\n\t\"./textsnippetoutlined.json\": 59455,\n\t\"./texture.json\": 97430,\n\t\"./theatercomedy.json\": 42279,\n\t\"./theatercomedyoutlined.json\": 4097,\n\t\"./theaters.json\": 34173,\n\t\"./theatersoutlined.json\": 10423,\n\t\"./thermostat.json\": 96354,\n\t\"./thermostatauto.json\": 12197,\n\t\"./thirteenmp.json\": 67237,\n\t\"./thirteenmpoutlined.json\": 34175,\n\t\"./thirtyfps.json\": 92922,\n\t\"./thirtyfpsselect.json\": 65186,\n\t\"./threegmobiledata.json\": 36724,\n\t\"./threek.json\": 19538,\n\t\"./threekoutlined.json\": 77332,\n\t\"./threekplus.json\": 75022,\n\t\"./threekplusoutlined.json\": 60216,\n\t\"./threemp.json\": 18732,\n\t\"./threempoutlined.json\": 77006,\n\t\"./threeoputlined.json\": 81419,\n\t\"./threep.json\": 73195,\n\t\"./threesixty.json\": 92088,\n\t\"./thumbdown.json\": 63165,\n\t\"./thumbdownoutlined.json\": 34775,\n\t\"./thumbsupdown.json\": 951,\n\t\"./thumbsupdownoutlined.json\": 88113,\n\t\"./thumbup.json\": 25804,\n\t\"./thumbupoutlined.json\": 76078,\n\t\"./tibia.json\": 61088,\n\t\"./tibiaalt.json\": 17107,\n\t\"./tiktok.json\": 51193,\n\t\"./tiktokoutlined.json\": 92507,\n\t\"./timelapse.json\": 89743,\n\t\"./timeline.json\": 96744,\n\t\"./timer.json\": 78776,\n\t\"./timer10.json\": 44101,\n\t\"./timer10select.json\": 76669,\n\t\"./timer3.json\": 64109,\n\t\"./timer3select.json\": 97749,\n\t\"./timeroff.json\": 74489,\n\t\"./timesonemobiledata.json\": 15347,\n\t\"./timetoleave.json\": 7662,\n\t\"./timetoleaveoutlined.json\": 35704,\n\t\"./title.json\": 95211,\n\t\"./toc.json\": 94471,\n\t\"./today.json\": 21428,\n\t\"./todayoutlined.json\": 11894,\n\t\"./toggleoffoutlined.json\": 65598,\n\t\"./toggleon.json\": 59494,\n\t\"./toggleonoutlined.json\": 40688,\n\t\"./toll.json\": 61402,\n\t\"./tonality.json\": 69067,\n\t\"./topic.json\": 57234,\n\t\"./topicoutlined.json\": 84372,\n\t\"./totaldissolvedsolids.json\": 98152,\n\t\"./touchapp.json\": 73413,\n\t\"./touchappoutlined.json\": 8159,\n\t\"./tour.json\": 94501,\n\t\"./touroutlined.json\": 47039,\n\t\"./toys.json\": 76182,\n\t\"./toysoutlined.json\": 60896,\n\t\"./trackchanges.json\": 16663,\n\t\"./traffic.json\": 12704,\n\t\"./trafficoutlined.json\": 6090,\n\t\"./train.json\": 51707,\n\t\"./trainoutlined.json\": 20525,\n\t\"./tram.json\": 42291,\n\t\"./tramoutlined.json\": 42181,\n\t\"./transferwithinastation.json\": 41930,\n\t\"./transform.json\": 2753,\n\t\"./transgender.json\": 84250,\n\t\"./transitenterexit.json\": 42580,\n\t\"./translate.json\": 23683,\n\t\"./travelexplore.json\": 64390,\n\t\"./trendingdown.json\": 39802,\n\t\"./trendingflat.json\": 70397,\n\t\"./trendingup.json\": 50787,\n\t\"./triporigin.json\": 5938,\n\t\"./try.json\": 9356,\n\t\"./tryoutlined.json\": 78894,\n\t\"./tty.json\": 84034,\n\t\"./ttyoutlined.json\": 56708,\n\t\"./tune.json\": 11897,\n\t\"./tungsten.json\": 76131,\n\t\"./tungstenoutlined.json\": 37461,\n\t\"./turnedin.json\": 9118,\n\t\"./turnedinnot.json\": 12383,\n\t\"./tv.json\": 83245,\n\t\"./tvoff.json\": 91706,\n\t\"./twelvemp.json\": 50287,\n\t\"./twelvempoutlined.json\": 30665,\n\t\"./twentyfourmp.json\": 14827,\n\t\"./twentyfourmpoutlined.json\": 56797,\n\t\"./twentyonemp.json\": 79859,\n\t\"./twentyonempoutlined.json\": 67173,\n\t\"./twentythreemp.json\": 16523,\n\t\"./twentythreempoutlined.json\": 68829,\n\t\"./twentytwomp.json\": 95757,\n\t\"./twentytwompoutlined.json\": 36775,\n\t\"./twentyzeromp.json\": 90653,\n\t\"./twentyzerompoutlined.json\": 79511,\n\t\"./twitter.json\": 60714,\n\t\"./twok.json\": 51400,\n\t\"./twokoutlined.json\": 59186,\n\t\"./twokplus.json\": 20360,\n\t\"./twokplusoutlined.json\": 43666,\n\t\"./twomp.json\": 55674,\n\t\"./twompoutlined.json\": 35260,\n\t\"./twowheeler.json\": 46905,\n\t\"./ulnaradius.json\": 3209,\n\t\"./ulnaradiusalt.json\": 49412,\n\t\"./upcoming.json\": 13805,\n\t\"./upcomingoutlined.json\": 86887,\n\t\"./update.json\": 53414,\n\t\"./updatedisabled.json\": 72766,\n\t\"./upgrade.json\": 64277,\n\t\"./upload.json\": 74674,\n\t\"./uploadfile.json\": 20616,\n\t\"./uploadoutlined.json\": 65428,\n\t\"./urology.json\": 38080,\n\t\"./usb.json\": 36291,\n\t\"./usboff.json\": 4704,\n\t\"./vaccines.json\": 59167,\n\t\"./verified.json\": 8911,\n\t\"./verifiedoutlined.json\": 77321,\n\t\"./verifieduser.json\": 54444,\n\t\"./verifieduseroutlined.json\": 90702,\n\t\"./verticalalignbottom.json\": 67161,\n\t\"./verticalaligncenter.json\": 80611,\n\t\"./verticalaligntop.json\": 43909,\n\t\"./verticalsplit.json\": 76315,\n\t\"./verticalsplitoutlined.json\": 96173,\n\t\"./vibration.json\": 53239,\n\t\"./videocall.json\": 58590,\n\t\"./videocalloutlined.json\": 17416,\n\t\"./videocam.json\": 1025,\n\t\"./videocameraback.json\": 41862,\n\t\"./videocamerabackoutlined.json\": 63056,\n\t\"./videocamerafront.json\": 62976,\n\t\"./videocamerafrontoutlined.json\": 64810,\n\t\"./videocamoff.json\": 69470,\n\t\"./videocamoffoutlined.json\": 55432,\n\t\"./videocamoutlined.json\": 227,\n\t\"./videogameasset.json\": 48652,\n\t\"./videogameassetoff.json\": 98733,\n\t\"./videogameassetoffoutlined.json\": 57511,\n\t\"./videogameassetoutlined.json\": 8782,\n\t\"./videolabel.json\": 51652,\n\t\"./videolibrary.json\": 40845,\n\t\"./videolibraryoutlined.json\": 28487,\n\t\"./videosettings.json\": 45787,\n\t\"./videostable.json\": 81421,\n\t\"./videostableoutlined.json\": 49991,\n\t\"./viewagenda.json\": 47706,\n\t\"./viewagendaoutlined.json\": 42364,\n\t\"./viewarray.json\": 60183,\n\t\"./viewcarousel.json\": 1760,\n\t\"./viewcarouseloutlined.json\": 58666,\n\t\"./viewcolumn.json\": 10564,\n\t\"./viewcolumnoutlined.json\": 34278,\n\t\"./viewcomfy.json\": 60082,\n\t\"./viewcomfyoutlined.json\": 54580,\n\t\"./viewcompact.json\": 59763,\n\t\"./viewcompactoutlined.json\": 54405,\n\t\"./viewday.json\": 46852,\n\t\"./viewdayoutlined.json\": 91622,\n\t\"./viewheadline.json\": 41646,\n\t\"./viewinar.json\": 11674,\n\t\"./viewinaroutlined.json\": 77468,\n\t\"./viewlist.json\": 14974,\n\t\"./viewlistoutlined.json\": 49960,\n\t\"./viewmodule.json\": 53806,\n\t\"./viewmoduleoutlined.json\": 95064,\n\t\"./viewquilt.json\": 46251,\n\t\"./viewquiltoutlined.json\": 84093,\n\t\"./viewsidebar.json\": 2142,\n\t\"./viewsidebaroutlined.json\": 23944,\n\t\"./viewstream.json\": 6210,\n\t\"./viewstreamoutlined.json\": 22340,\n\t\"./viewweek.json\": 41742,\n\t\"./viewweekoutlined.json\": 79512,\n\t\"./vignette.json\": 76505,\n\t\"./vignetteoutlined.json\": 41947,\n\t\"./villa.json\": 24253,\n\t\"./villaoutlined.json\": 99031,\n\t\"./visibility.json\": 74919,\n\t\"./visibilityoff.json\": 36900,\n\t\"./visibilityoffoutlined.json\": 21542,\n\t\"./visibilityoutlined.json\": 53697,\n\t\"./voicechat.json\": 34437,\n\t\"./voicechatoutlined.json\": 68351,\n\t\"./voicemail.json\": 39984,\n\t\"./voiceoveroff.json\": 29694,\n\t\"./voiceoveroffoutlined.json\": 48808,\n\t\"./volumedown.json\": 41449,\n\t\"./volumedownoutlined.json\": 93003,\n\t\"./volumemute.json\": 74564,\n\t\"./volumemuteoutlined.json\": 45222,\n\t\"./volumeoff.json\": 61494,\n\t\"./volumeoffoutlined.json\": 15776,\n\t\"./volumeup.json\": 41440,\n\t\"./volumeupoutlined.json\": 8618,\n\t\"./volunteeractivism.json\": 72605,\n\t\"./volunteeractivismoutlined.json\": 99095,\n\t\"./vpnkey.json\": 91160,\n\t\"./vpnkeyoutlined.json\": 78530,\n\t\"./vpnlock.json\": 44794,\n\t\"./vrpaclassic.json\": 5884,\n\t\"./vrpano.json\": 16995,\n\t\"./walllamp.json\": 14313,\n\t\"./wallpaper.json\": 51563,\n\t\"./warning.json\": 19161,\n\t\"./warningamber.json\": 91744,\n\t\"./wash.json\": 60860,\n\t\"./washoutlined.json\": 66942,\n\t\"./watch.json\": 9230,\n\t\"./watchlater.json\": 24148,\n\t\"./watchlateroutlined.json\": 63446,\n\t\"./watchoutlined.json\": 96248,\n\t\"./water.json\": 15654,\n\t\"./waterdamage.json\": 88999,\n\t\"./waterdamageoutlined.json\": 11521,\n\t\"./waterfallchart.json\": 15949,\n\t\"./waterpump.json\": 84172,\n\t\"./waves.json\": 31475,\n\t\"./wbauto.json\": 57137,\n\t\"./wbautooutlined.json\": 64243,\n\t\"./wbcloudy.json\": 55118,\n\t\"./wbcloudyoutlined.json\": 66328,\n\t\"./wbincandescent.json\": 35185,\n\t\"./wbincandescentoutlined.json\": 3891,\n\t\"./wbiridescent.json\": 92186,\n\t\"./wbiridescentoutlined.json\": 18044,\n\t\"./wbshade.json\": 93539,\n\t\"./wbsunny.json\": 46801,\n\t\"./wbsunnyoutlined.json\": 55123,\n\t\"./wbtwilight.json\": 23818,\n\t\"./wc.json\": 84193,\n\t\"./web.json\": 71027,\n\t\"./webasset.json\": 67225,\n\t\"./webassetoff.json\": 37622,\n\t\"./weekend.json\": 92200,\n\t\"./weekendoutlined.json\": 4594,\n\t\"./west.json\": 95140,\n\t\"./whatsapp.json\": 46289,\n\t\"./whatshot.json\": 80653,\n\t\"./whatshotoutlined.json\": 26631,\n\t\"./wheelchairpickup.json\": 34779,\n\t\"./wheretovote.json\": 11151,\n\t\"./wheretovoteoutlined.json\": 37257,\n\t\"./widgets.json\": 78512,\n\t\"./widgetsoutlined.json\": 49562,\n\t\"./wifi.json\": 79666,\n\t\"./wificalling.json\": 53658,\n\t\"./wificalling3.json\": 95303,\n\t\"./wificalling3outlined.json\": 70177,\n\t\"./wificallingoutlined.json\": 82876,\n\t\"./wifilock.json\": 59477,\n\t\"./wifioff.json\": 29139,\n\t\"./wifiprotectedsetup.json\": 26157,\n\t\"./wifitethering.json\": 16334,\n\t\"./wifitetheringoff.json\": 75775,\n\t\"./window.json\": 25043,\n\t\"./windowsensor.json\": 81441,\n\t\"./winebar.json\": 53123,\n\t\"./winebaroutlined.json\": 76021,\n\t\"./work.json\": 56122,\n\t\"./workoff.json\": 18075,\n\t\"./workoffoutlined.json\": 73005,\n\t\"./workoutline.json\": 96664,\n\t\"./workspaces.json\": 68029,\n\t\"./workspacesoutlined.json\": 25143,\n\t\"./wraptext.json\": 21612,\n\t\"./wronglocation.json\": 34955,\n\t\"./wronglocationoutlined.json\": 10077,\n\t\"./wysiwyg.json\": 41628,\n\t\"./x.json\": 90925,\n\t\"./yard.json\": 35315,\n\t\"./yardoutlined.json\": 81157,\n\t\"./youtube.json\": 83840,\n\t\"./youtubesearchedfor.json\": 78632,\n\t\"./zonepersonidle.json\": 52522,\n\t\"./zoomin.json\": 38163,\n\t\"./zoomout.json\": 41352,\n\t\"./zoomoutmap.json\": 53050\n};\n\nfunction webpackAsyncContext(req) {\n\treturn Promise.resolve().then(function() {\n\t\tif(!__webpack_require__.o(map, req)) {\n\t\t\tvar e = new Error(\"Cannot find module '\" + req + \"'\");\n\t\t\te.code = 'MODULE_NOT_FOUND';\n\t\t\tthrow e;\n\t\t}\n\n\t\tvar id = map[req];\n\t\treturn __webpack_require__.t(id, 1 | 16);\n\t});\n}\nwebpackAsyncContext.keys = function() { return Object.keys(map); };\nwebpackAsyncContext.id = 38732;\nmodule.exports = webpackAsyncContext;","// The chunk loading function for additional chunks\n// Since all referenced chunks are already included\n// in this file, this function is empty here.\n__webpack_require__.e = function() { return Promise.resolve(); };","var __WEBPACK_NAMESPACE_OBJECT__ = require(\"@cbmisorg/styles\");","\"use client\";\r\n\r\nimport { StyleBuilder, styleVariables, cssKeys, mainTheme, styleFunction } from \"@cbmisorg/styles\";\r\n\r\nexport default (objThemeInfo) => {\r\n const cssObject = objThemeInfo?.cssObject ? objThemeInfo?.cssObject : mainTheme?.cssObject;\r\n\r\n const classesName = {\r\n icon_container: `${styleVariables?.prefixDefaultClassName}_icon_container`,\r\n icon: `${styleVariables?.prefixDefaultClassName}_icon`,\r\n sx: `${styleVariables?.prefixDefaultClassName}_icon_sx`,\r\n };\r\n const style = StyleBuilder({\r\n blnRandomPrefix: false,\r\n blnIsDefaultStyle: true,\r\n blnCbmisStyle: true,\r\n objStyles: {\r\n [classesName?.icon_container]: {\r\n position: \"relative\",\r\n background: cssObject?.color?.[cssKeys?.transparent],\r\n backgroundColor: cssObject?.color?.[cssKeys?.transparent],\r\n margin: \"auto\",\r\n padding: 0,\r\n zIndex: 1,\r\n display: \"flex\",\r\n alignItems: \"center\",\r\n justifyContent: \"center\",\r\n placeContent: \"center\",\r\n outline: \"none\",\r\n border: \"none\",\r\n height: \"fit-content\",\r\n width: \"fit-content\",\r\n boxSizing: cssObject?.boxSizing?.[cssKeys?.borderBox],\r\n // fontSize: cssObject?.text?.size?.body1,\r\n overflow: \"hidden\",\r\n },\r\n },\r\n });\r\n\r\n const styleSx = StyleBuilder({\r\n blnRandomPrefix: true,\r\n blnIsDefaultStyle: false,\r\n blnCbmisStyle: true,\r\n objStyles: {\r\n [classesName?.icon_container]: (props) => {\r\n return {\r\n \"&hover\": props?.onClick\r\n ? {\r\n background: cssObject?.color?.[cssKeys?.bodyColorBgLight],\r\n cursor: \"pointer\",\r\n }\r\n : null,\r\n color: styleFunction.checkColorReturnValue(props?.color || cssObject?.color?.[cssKeys?.currentColor]),\r\n };\r\n },\r\n [classesName?.sx]: (props) => {\r\n return {\r\n ...props?.sx,\r\n };\r\n },\r\n },\r\n });\r\n\r\n const styleIconBody = StyleBuilder({\r\n blnRandomPrefix: false,\r\n blnIsDefaultStyle: true,\r\n blnCbmisStyle: true,\r\n objStyles: {\r\n [classesName?.icon]: {\r\n fill: cssObject?.color?.[cssKeys?.currentColor],\r\n // width:\"100%\",\r\n // height:\"100%\"\r\n },\r\n },\r\n });\r\n\r\n const styleSxIconBody = StyleBuilder({\r\n blnRandomPrefix: true,\r\n blnIsDefaultStyle: false,\r\n blnCbmisStyle: true,\r\n objStyles: {\r\n [classesName?.icon]: (props) => {\r\n if (props?.size) {\r\n return {\r\n width: props?.size,\r\n height: props?.size,\r\n };\r\n }\r\n if (props?.fontSize) {\r\n return { ...props?.fontSize };\r\n }\r\n return {\r\n width: cssObject?.text?.[cssKeys?.size]?.[cssKeys?.body1],\r\n height: cssObject?.text?.[cssKeys?.size]?.[cssKeys?.body1],\r\n };\r\n },\r\n },\r\n });\r\n return {\r\n classesName,\r\n style,\r\n styleSx,\r\n styleIconBody,\r\n styleSxIconBody,\r\n };\r\n};\r\n\r\n// if (typeof window !== \"undefined\") {\r\n// icon_container.classList.add(classesSx?.[classesName?.sx]);\r\n// }\r\n","\"use client\";\r\nimport React, { useEffect, useRef, useState } from \"react\";\r\nimport { pkgConfigIcon } from \".\";\r\nimport IconStyle from \"./IconStyle\";\r\n\r\nfunction IconBody({ icon, theTheme, comID, size, fontSize }) {\r\n const refIcon = useRef({ strIconName: null });\r\n const [dataIcon, setDataIcon] = useState(null);\r\n const { classesName, styleIconBody, styleSxIconBody } = IconStyle(theTheme);\r\n const classes = styleIconBody();\r\n const classesSx = styleSxIconBody({ size , fontSize});\r\n\r\n useEffect(() => {\r\n const funGetIcon = () => {\r\n try {\r\n const iconName = String(icon).toLowerCase().trim();\r\n if (refIcon?.current?.strIconName === iconName) {\r\n return;\r\n }\r\n\r\n return import(`./icons/${iconName}.json`)\r\n .then((iconSrc) => {\r\n let parseIcon = JSON.parse(iconSrc?.default || iconSrc);\r\n let dataIcon = parseIcon?.[iconName];\r\n\r\n refIcon.current.strIconName = iconName;\r\n setDataIcon(dataIcon);\r\n })\r\n .catch((error) => {\r\n if (pkgConfigIcon?.blnIsTestingMode) {\r\n console.log(error);\r\n console.error(\"Icon ( \" + icon + \" ) not found.\");\r\n }\r\n refIcon.current.strIconName = iconName;\r\n setDataIcon(null);\r\n });\r\n } catch (error) {\r\n if (pkgConfigIcon?.blnIsTestingMode) {\r\n console.error(\"Icon ( \" + icon + \" ) not found.\");\r\n }\r\n refIcon.current.strIconName = null;\r\n setDataIcon(null);\r\n }\r\n };\r\n funGetIcon();\r\n // const icon_container = typeof document !== \"undefined\" ? document.getElementById(comID) : null;\r\n // if (icon_container) {\r\n // refIcon.current.comSize = window?.getComputedStyle(icon_container)?.getPropertyValue(\"font-size\");\r\n // }\r\n }, [icon]);\r\n return (\r\n \r\n \r\n {!dataIcon ? null : (\r\n <>\r\n {dataIcon?.[\"circle\"]\r\n ? dataIcon?.[\"circle\"].map((crl, index) => {\r\n return ;\r\n })\r\n : null}\r\n\r\n {dataIcon?.[\"path\"]\r\n ? dataIcon?.[\"path\"].map((d, index) => {\r\n return ;\r\n })\r\n : null}\r\n\r\n {dataIcon?.[\"line\"]\r\n ? dataIcon[\"line\"].map((line, index) => {\r\n return (\r\n \r\n );\r\n })\r\n : null}\r\n >\r\n )}\r\n \r\n \r\n );\r\n}\r\n\r\nexport default IconBody;\r\n","\"use client\";\r\n// @ts-nocheck\r\nimport React, { forwardRef, useContext, useId, useMemo } from \"react\";\r\nimport { styleFunction, ContextThemeProvider, getSpecificCssRule } from \"@cbmisorg/styles\";\r\nimport IconStyle from \"./IconStyle\";\r\nimport IconBody from \"./IconBody\";\r\n\r\nconst Icon = forwardRef((/**@type{any}*/ props, ref) => {\r\n const { icon, color, size, title, sx, hidden, disabled, dir, id, className, ...rest } = props;\r\n const comID = id || String(useId()).slice(1, -1) + \"icon\";\r\n const theTheme = useContext(ContextThemeProvider);\r\n\r\n const { classesName, style, styleSx } = IconStyle(theTheme);\r\n const classes = style();\r\n const classesSx = styleSx({ sx, color, disabled, onClick: props?.onClick ? true : false });\r\n\r\n const itemClasses = styleFunction.getClassName(\r\n classes?.[classesName?.icon_container],\r\n classesSx?.[classesName?.icon_container],\r\n classesSx?.[classesName?.sx],\r\n styleFunction.CheckDirectionItem(dir),\r\n styleFunction.CheckDisabledItem(disabled),\r\n styleFunction.CheckHiddenItem(hidden),\r\n styleFunction.checkExistsMargin(rest),\r\n styleFunction.checkExistsPadding(rest),\r\n className\r\n );\r\n\r\n // useEffect(() => {\r\n // // setComSize(\"84px\");\r\n // if (icon_container) {\r\n // const containerFontSize = window?.getComputedStyle(icon_container)?.getPropertyValue(\"font-size\");\r\n\r\n // if (containerFontSize !== comSize) {\r\n // setComSize(containerFontSize);\r\n // }\r\n // }\r\n\r\n // console.log(classesSx, \"classesSx\");\r\n // console.log(classesSx?.[classesName?.sx], \"classesSx?.[classesName?.sx]\");\r\n // }, [icon, window?.getComputedStyle(icon_container)?.getPropertyValue(\"font-size\")]);\r\n\r\n const fontSize = useMemo(() => {\r\n const fontSizeSx = getSpecificCssRule([\"fontSize\"], sx, (key, value) => {\r\n return { height: value, width: value };\r\n });\r\n if (!Object.keys(fontSizeSx || {})?.length) {\r\n return null;\r\n }\r\n return fontSizeSx;\r\n }, [sx]);\r\n\r\n return props?.onClick ? (\r\n \r\n {typeof icon === \"string\" ? : null}\r\n \r\n ) : (\r\n \r\n {typeof icon === \"string\" ? : null}\r\n
\r\n );\r\n});\r\n\r\nexport default Icon;\r\n","const objIconsCategories = {\r\n account: [\"accountbox\", \"accountboxoutlined\", \"accountcircle\", \"accountcircleoutlined\",\"assignmentind\",\"assignmentindoutlined\",\"badge\",\"badgeoutlined\",\"threeoputlined\",\"threep\",\"contactpage\",\"contactpageoutlined\",\"contacts\",\"contactsoutlined\",\"howtoreg\",\"howtoregoutlined\",\"manageaccounts\",\"manageaccountsoutlined\",\"noaccounts\",\"noaccountsoutlined\",\"portrait\",\"portraitoutlined\",\"recentactors\",\"recentactorsoutlined\",\"switchaccount\",\"switchaccountoutlined\"],\r\n accessibility: ['accessibilitynew', 'accessible', 'accessibleforward', 'notaccessible'],\r\n add: [\"add\", \"addcircle\", \"addcircleoutlined\",\"assistant\",\"assistantoutlined\",\"tryoutlined\",\"try\",\"controlpoint\",\"controlpointduplicate\",\"dashboardcustomize\",\"dashboardcustomizeoutlined\",\"datasaveron\",\"libraryadd\",\"libraryaddoutlined\",\"loupe\",\"mapsugc\",\"mapsugcoutlined\",\"more\",\"morehoriz\",\"moreoutlined\",\"morevert\",\"playlistadd\",\"queue\",\"queueoutlined\"],\r\n alert: [\"addalert\", \"addalertoutlined\", \"announcement\", \"announcementoutlined\",\"assignmentlate\",\"assignmentlateoutlined\",\"warningamber\",\"warning\",\"discfluid\",\"discfluidoutlined\",\"error\",\"erroroutlined\",\"feedback\",\"feedbackoutlined\",\"fmdbad\",\"fmdbadoutlined\",\"info\",\"infooutlined\",\"newreleases\",\"newreleasesoutlined\",\"priorityhigh\",\"privacytip\",\"privacytipoutlined\",\"report\",\"reportoff\",\"reportoffoutlined\",\"reportoutlined\",\"reportproblem\",\"reportproblemoutlined\",\"sdcardalert\",\"sdcardalertoutlined\"],\r\n align: [\"alignhorizontalcenter\", \"alignhorizontalcenteroutlined\", \"alignhorizontalleft\", \"alignhorizontalright\", \"alignverticalbottom\", \"alignverticalcenter\", \"alignverticaltop\"],\r\n\r\n attach:[\"attachfile\",\"attachment\",\"uploadfile\",\"filepresent\",\"link\",\"linkoff\",\"share\",\"shareoutlined\"],\r\n art: [\"brush\",\"brushoutlined\"],\r\n activity:[\"downhillskiing\"],\r\n animal:[\"pestcontrolrodent\",\"pestcontrolrodentoutlined\",\"pets\"],\r\n\r\n arrow: [\"subdirectoryarrowleft\",\"subdirectoryarrowright\",\"settingsethernet\",\"settingsbackuprestore\",\"restartalt\",\"restore\",\"repeatone\",\"replay\",\"replay5\",\"replay10\",\"replay30\",\"replaycirclefilled\",\"reply\",\"replyall\",\"repeat\",\"altroute\", \"arrowback\", \"arrowbackios\", \"arrowbackiosnew\", \"arrowbackiosnew\", \"arrowcircledown\", \"arrowcircledownoutlined\", \"arrowcircleup\", \"arrowcircleupoutlined\", \"arrowdownward\", \"arrowdropdown\", \"arrowdropdowncircle\", \"arrowdropdowncircleoutlined\", \"arrowdropup\", \"arrowforward\", \"arrowforwardios\", \"arrowleft\", \"arrowright\", \"arrowupward\",\"assignmentreturn\",\"assignmentreturned\",\"assignmentreturnedoutlined\",\"assignmentreturnoutlined\",\"assistantdirection\",\"assistantdirectionoutlined\",\"autorenew\",\"zoomoutmap\",\"west\",\"verticalaligntop\",\"verticalaligncenter\",\"verticalalignbottom\",\"uploadoutlined\",\"upload\",\"upgrade\",\"updatedisabled\",\"update\",\"trendingup\",\"trendingflat\",\"trendingdown\",\"transitenterexit\",\"transgender\",\"transform\",\"timeline\",\"threesixty\",\"cached\",\"callmade\",\"callmerge\",\"callmissed\",\"callmissedoutgoing\",\"callreceived\",\"callsplit\",\"changecircle\",\"changecircleoutlined\",\"chevronleft\",\"chevronright\",\"closefluidscreen\",\"comparearrows\",\"compress\",\"directions\",\"directionsoff\",\"directionsoutlined\",\"doublearrow\",\"east\",\"exittoapp\",\"expand\",\"expandless\",\"expandmore\",\"fastforward\",\"fastforwardoutlined\",\"fastrewind\",\"fastrewindoutlined\",\"firstpage\",\"forward\",\"forward5\",\"forward10\",\"forward30\",\"forwardoutlined\",\"height\",\"importexport\",\"input\",\"keyboardarrowdown\",\"keyboardarrowleft\",\"keyboardarrowright\",\"keyboardarrowup\",\"keyboardbackspace\",\"keyboardcapslock\",\"keyboardreturn\",\"keyboardtab\",\"label\",\"labelimportant\",\"labeloff\",\"labeloffoutlined\",\"labeloutlined\",\"lastpage\",\"launch\",\"login\",\"logout\",\"loop\",\"lowpriority\",\"mobiledataoff\",\"modeltraining\",\"moving\",\"navigatenext\",\"multiplestop\",\"navigatebefore\",\"navigationoutlined\",\"navigation\",\"nearme\",\"nearmedisabled\",\"nearmedisabledoutlined\",\"nearmeoutlined\",\"nextplan\",\"nextplanoutlined\",\"north\",\"northeast\",\"northwest\",\"openinfull\",\"openinnew\",\"openinnewoff\",\"openwith\",\"outbound\",\"outboundoutlined\",\"playarrow\",\"playarrowoutlined\",\"playcircle\",\"playcircleoutlined\",\"playdisabled\",\"playdisabledoutlined\",\"redo\",\"refresh\",\"rotate90degreesccw\",\"rotateleft\",\"rotateright\",\"schedulesend\",\"schedulesendoutlined\",\"send\",\"sendandarchive\",\"sendandarchiveoutlined\",\"sendoutlined\",\"shortcut\",\"showchart\",\"shuffle\",\"skipnext\",\"skipnextoutlined\",\"skipprevious\",\"skippreviousoutlined\",\"slowmotionvideo\",\"south\",\"southeast\",\"southwest\",\"swapcalls\",\"swaphoriz\",\"swaphorizontalcircle\",\"swaphorizontalcircleoutlined\",\"swapvert\",\"swapverticalcircle\",\"swapverticalcircleoutlined\",\"switchleft\",\"switchright\",\"sync\",\"syncalt\",\"syncdisabled\",\"syncproblem\"],\r\n\r\n box: [\"addbox\",\"addboxoutlined\", \"allinbox\", \"allinboxoutlined\"],\r\n business: [\"addbusiness\", \"addbusinessoutlined\"],\r\n book: [\"autostories\",\"autostoriesoutlined\",\"book\",\"bookoutlined\",\"bookmark\",\"bookmarkoutlined\",\"bookmarkadd\",\"bookmarkaddoutlined\",\"bookmarkadded\",\"bookmarkaddedoutlined\",\"bookmarkremove\",\"bookmarkremoveoutlined\",\"bookmarks\",\"bookmarksoutlined\",\"turnedinnot\",\"turnedin\",\"class\",\"classoutlined\",\"collectionsbookmark\",\"collectionsbookmarkoutlined\",\"commentbank\",\"commentbankoutlined\",\"contentpaste\",\"contentpasteoff\",\"importcontacts\",\"locallibrary\",\"locallibraryoutlined\",\"menubook\"],\r\n baby:[\"aabychangingstation\",\"bedroombaby\",\"bedroombabyoutlined\",\"childcare\",\"childfriendly\",\"childfriendlyoutlined\",\"crib\",\"criboutlined\",\"nostroller\",\"nostrolleroutlined\",\"stroller\",\"strolleroutlined\"],\r\n bag: [\"backpack\",\"backpackoutlined\",\"workoutline\",\"workoffoutlined\",\"workoff\",\"work\",\"businesscenter\",\"businesscenteroutlined\",\"cardtravel\",\"cases\",\"casesoutlined\",\"homerepairservice\",\"homerepairserviceoutlined\",\"integrationinstructions\",\"localmall\",\"localmalloutlined\",\"luggage\",\"luggageoutlined\",\"nextweek\",\"nextweekoutlined\",\"nobackpack\",\"nobackpackoutlined\",\"noluggage\",\"noluggageoutlined\",\"shop\",\"shop2\",\"shop2outlined\",\"shopoutlined\",\"shoppingbag\",\"shoppingbagoutlined\",\"shoppingbasket\",\"shoppingbasketoutlined\"],\r\n block: [\"block\"],\r\n\r\n comment: [\"addcomment\", \"addcommentoutlined\"],\r\n circle: [\"adjust\", \"animation\",\"attribution\",\"blurcircular\",\"brightness1\",\"brightness1outlined\",\"workspacesoutlined\",\"workspaces\",\"triporigin\",\"trackchanges\",\"tonality\",\"toll\",\"timelapse\",\"bubblechart\",\"bubblechartoutlined\",\"circle\",\"circleoutlined\",\"datasaveroff\",\"donutlarge\",\"donutsmall\",\"donutsmalloutlined\",\"dragindicator\",\"fibermanualrecord\",\"fibermanualrecordoutlined\",\"fibersmartrecord\",\"fibersmartrecordoutlined\",\"filtertiltshift\",\"flipcameraandroid\",\"groupwork\",\"groupworkoutlined\",\"hdrweak\",\"hidesource\",\"motionphotosoff\",\"motionphotosoffoutlined\",\"panoramafisheye\",\"panoramaphotosphere\",\"panoramaphotosphereselect\",\"pending\",\"pendingoutlined\",\"radiobuttonchecked\",\"radiobuttonunchecked\",\"runningwitherrors\",\"scatterplot\",\"scatterplotoutlined\",\"stopcircle\",\"stopcircleoutlined\"],\r\n car: [\"airportshuttle\", \"airportshuttleoutlined\",\"bikescooter\",\"bluetoothdrive\",\"bluetoothdriveoutlined\",\"tramoutlined\",\"tram\",\"trainoutlined\",\"train\",\"toysoutlined\",\"toys\",\"twowheeler\",\"timetoleaveoutlined\",\"timetoleave\",\"taxialertoutlined\",\"taxialert\",\"busalert\",\"busalertoutlined\",\"carrental\",\"carrentaloutlined\",\"carrepair\",\"carrepairoutlined\",\"commute\",\"deliverydining\",\"deliverydiningoutlined\",\"departureboard\",\"departureboardoutlined\",\"directionsbike\",\"directionsbus\",\"directionsbusoutlined\",\"directionscar\",\"directionscaroutlined\",\"directionsrailway\",\"directionsrailwayoutlined\",\"directionssubway\",\"directionssubwayoutlined\",\"driveeta\",\"driveetaoutlined\",\"electricbike\",\"electriccar\",\"electriccaroutlined\",\"electricmoped\",\"electricmopedoutlined\",\"electricrickshaw\",\"electricrickshawoutlined\",\"electricscooter\",\"emojitransportation\",\"escalator\",\"escalatoroutlined\",\"evstation\",\"evstationoutlined\",\"garage\",\"garageoutlined\",\"localcarwash\",\"localcarwashoutlined\",\"localgasstation\",\"localgasstationoutlined\",\"localshipping\",\"localshippingoutlined\",\"localtaxi\",\"localtaxioutlined\",\"moped\",\"mopedoutlined\",\"notransfer\",\"notransferoutlined\",\"pedalbike\",\"railwayalert\",\"railwayalertoutlined\",\"rvhookup\",\"speed\",\"subway\",\"subwayoutlined\"],\r\n charts: [\"accounttree\", \"accounttreeoutlined\", \"addchart\", \"analytics\", \"analyticsoutlined\",\"assessment\",\"assessmentoutlined\",\"attractions\",\"autograph\",\"barchart\",\"blurlinear\",\"bluroff\",\"bluron\",\"waterfallchart\",\"tune\",\"devicehub\",\"equalizer\",\"insertchart\",\"insertchartoutlined\",\"leaderboard\",\"leaderboardoutlined\",\"mediation\",\"multilinechart\",\"nat\",\"pivottablechart\",\"poll\",\"polloutlined\",\"querystats\",\"radar\",\"schema\",\"schemaoutlined\",\"stackedbarchart\",\"stackedlinechart\",\"tablechart\",\"tablechartoutlined\"],\r\n check: [\"assignmentturnedin\",\"assignmentturnedinoutlined\",\"beenhere\",\"beenhereoutlined\",\"verifieduseroutlined\",\"verifieduser\",\"verifiedoutlined\",\"verified\",\"taskoutlined\",\"taskalt\",\"task\",\"check\",\"checkbox\",\"checkboxoutlined\",\"checkcircle\",\"checkcircleoutlined\",\"clouddone\",\"clouddoneoutlined\",\"domainverification\",\"done\",\"doneall\",\"doneoutline\",\"downloaddone\",\"editattributes\",\"editattributesoutlined\",\"factcheck\",\"factcheckoutlined\",\"filedownloaddone\",\"filedownloaddoneoutlined\",\"inventoryoutlined\",\"libraryaddcheck\",\"libraryaddcheckoutlined\",\"offlinepin\",\"offlinepinoutlined\",\"playlistaddcheck\",\"publishedwithchanges\",\"removedone\",\"removedoneoutlined\",\"rule\"],\r\n clothes:[\"checkroom\",\"drycleaning\",\"drycleaningoutlined\",\"iron\",\"ironoutlined\",\"locallaundryservice\",\"locallaundryserviceoutlined\"],\r\n celebration:[\"cardgiftcard\",\"celebration\",\"celebrationoutlined\",\"emojievents\",\"emojieventsoutlined\",\"festival\",\"festivaloutlined\",\"redeem\",\"stream\"],\r\n copy:[\"filecopy\",\"filecopyoutlined\"],\r\n color:[\"invertcolors\",\"invertcolorsoff\",\"opacity\",\"palette\",\"paletteoutlined\",\"gradient\",\"salinity\",\"totaldissolvedsolids\"],\r\n\r\n delete: [\"removecircle\",\"removecircleoutlined\",\"autodelete\",\"autodeleteoutlined\",\"backspace\",\"backspaceoutlined\",\"cancel\",\"canceloutlined\",\"cancelpresentation\",\"cancelschedulesend\",\"cancelschedulesendoutlined\",\"clear\",\"close\",\"dangerous\",\"dangerousoutlined\",\"delete\",\"deleteforever\",\"deleteforeveroutlined\",\"deleteoutlined\",\"deleteoutlined\",\"deletesweepoutlined\",\"disabledbydefault\",\"disabledbydefaultoutlined\",\"dodisturb\",\"dodisturbalt\",\"dodisturboff\",\"dodisturboffoutlined\",\"dodisturbon\",\"dodisturbonoutlined\",\"donotdisturb\",\"donotdisturbalt\",\"donotdisturboff\",\"donotdisturboffoutlined\",\"donotdisturbon\",\"donotdisturbonoutlined\",\"donotdisturbontotalsilence\",\"donotstep\",\"donotstepoutlined\",\"donottouch\",\"donottouchoutlined\",\"highlightoff\",\"indeterminatecheckbox\",\"indeterminatecheckboxoutlined\",\"notinterested\",\"restorefromtrash\"],\r\n date:[\"todayoutlined\",\"today\",\"calendartoday\",\"calendartodayoutlined\",\"event\",\"eventoutlined\",\"eventavailable\",\"eventavailableoutlined\",\"eventbusy\",\"eventbusyoutlined\",\"eventnote\",\"eventnoteoutlined\"],\r\n download:[\"downloadforoffline\",\"clouddownload\",\"clouddownloadoutlined\",\"download\",\"downloadforofflineoutlined\",\"downloading\",\"downloadoutlined\",\"filedownload\",\"filedownloadoutlined\",\"filedownloadoff\",\"filedownloadoffoutlined\",\"getapp\",\"getappoutlined\",\"movetoinbox\",\"movetoinboxoutlined\",\"playforwork\",\"savealt\",\"systemupdatealt\"],\r\n dialoug:[\"forum\",\"forumoutlined\",\"markchatread\",\"markchatreadoutlined\",\"markchatunread\",\"markchatunreadoutlined\",\"modecomment\",\"modecommentoutlined\",\"questionanswer\",\"questionansweroutlined\",\"quickreply\",\"quickreplyoutlined\",\"ratereview\",\"ratereviewoutlined\",\"sms\",\"smsfailed\",\"smsfailedoutlined\",\"smsoutlined\"],\r\n\r\n ecommerce: [\"addshoppingcart\",\"basket\",\"localgrocerystore\",\"localgrocerystoreoutlined\",\"productionquantitylimits\",\"receipt\",\"receiptlong\",\"receiptlongoutlined\",\"receiptoutlined\",\"removeshoppingcart\",\"removeshoppingcartoutlined\",\"shoppingcart\",\"shoppingcartoutlined\"],\r\n emoji: [\"addreaction\", \"addreactionoutlined\",\"theatercomedyoutlined\",\"theatercomedy\",\"emojiemotions\",\"emojiemotionsoutlined\",\"outlet\",\"outletoutlined\"],\r\n email: [\"alternateemail\",\"attachemail\",\"attachemailoutlined\",\"contactmail\",\"contactmailoutlined\",\"drafts\",\"draftsoutlined\",\"email\",\"emailoutlined\",\"inbox\",\"inboxoutlined\",\"markasunread\",\"markasunreadoutlined\",\"markemailread\",\"markemailreadoutlined\",\"markemailunread\",\"markemailunreadoutlined\",\"markunread\",\"markunreadoutlined\"],\r\n effect: [\"autofixhigh\",\"autofixhighoutlined\",\"autofixnormal\",\"autofixnormaloutlined\",\"autofixoff\",\"autofixoffoutlined\",\"wbiridescentoutlined\",\"wbiridescent\",\"viewinaroutlined\",\"viewinar\",\"upcomingoutlined\",\"upcoming\",\"touchappoutlined\",\"touchapp\",\"theatersoutlined\",\"theaters\",\"cable\",\"controlcamera\",\"gesture\",\"insights\"],\r\n extension:[\"extension\",\"extensionoff\",\"extensionoffoutlined\",\"extensionoutlined\"],\r\n education:[\"school\",\"schooloutlined\"],\r\n\r\n flag:[\"assistantphoto\",\"assistantphotooutlined\",\"touroutlined\",\"tour\",\"emojiflags\",\"flag\",\"flagoutlined\",\"golfcourse\"],\r\n food:[\"bakerydining\",\"bakerydiningoutlined\",\"blender\",\"blenderoutlined\",\"breakfastdining\",\"breakfastdiningoutlined\",\"winebaroutlined\",\"winebar\",\"tapasoutlined\",\"tapas\",\"takeoutdiningoutlined\",\"takeoutdining\",\"brunchdining\",\"brunchdiningoutlined\",\"cake\",\"cakeoutlined\",\"coffee\",\"coffeemaker\",\"coffeemakeroutlined\",\"coffeeoutlined\",\"dining\",\"diningoutlined\",\"dinnerdining\",\"dinnerdiningoutlined\",\"emojifoodbeverage\",\"emojifoodbeverageoutlined\",\"fastfood\",\"fastfoodoutlined\",\"flatware\",\"foodbank\",\"foodbankoutlined\",\"freebreakfast\",\"freebreakfastoutlined\",\"grain\",\"icecream\",\"icecreamoutlined\",\"localcafe\",\"localcafeoutlined\",\"localdining\",\"localdrink\",\"localdrinkoutlined\",\"localpizza\",\"localpizzaoutlined\",\"lunchdining\",\"lunchdiningoutlined\",\"nodrinks\",\"nodrinksoutlined\",\"nofood\",\"nofoodoutlined\",\"nomeals\",\"outdoorgrill\",\"outdoorgrilloutlined\",\"ramendining\",\"ramendiningoutlined\",\"restaurant\",\"restaurantmenu\",\"ricebowl\",\"ricebowloutlined\",\"roomservice\",\"roomserviceoutlined\",\"setmeal\",\"setmealoutlined\"],\r\n feelings: [\"volunteeractivismoutlined\",\"volunteeractivism\",\"thumbupoutlined\",\"thumbup\",\"thumbsupdownoutlined\",\"thumbsupdown\",\"thumbdownoutlined\",\"thumbdown\",\"favorite\",\"favoriteoutlined\",\"recommend\",\"recommendoutlined\",\"sentimentdissatisfied\",\"sentimentdissatisfiedoutlined\",\"sentimentneutral\",\"sentimentneutraloutlined\",\"sentimentsatisfied\",\"sentimentsatisfiedoutlined\",\"sentimentverydissatisfied\",\"sentimentverydissatisfiedoutlined\",\"sentimentverysatisfied\",\"sentimentverysatisfiedoutlined\"],\r\n folder: [\"createnewfolder\",\"createnewfolderoutlined\",\"folder\",\"folderopen\",\"folderoutlined\",\"foldershared\",\"foldersharedoutlined\",\"folderspecial\",\"folderspecialoutlined\",\"inventory\",\"inventory2\",\"rulefolder\",\"rulefolderoutlined\",\"snippetfolder\",\"snippetfolderoutlined\",\"drivefilemove\",\"drivefilemoveoutlined\",],\r\n file:[\"insertdrivefile\",\"insertdrivefileoutlined\",\"note\",\"noteaddoutlined\",\"notealt\",\"notealtoutlined\",\"noteoutlined\",\"plagiarism\",\"plagiarismoutlined\",\"playlesson\",\"playlessonoutlined\",\"restorepage\",\"restorepageoutlined\",\"save\",\"saveoutlined\",\"summarize\",\"summarizeoutlined\"],\r\n\r\n game:[\"videogameassetoffoutlined\",\"videogameassetoff\",\"videogameassetoutlined\",\"videogameasset\",\"catchingpokemon\",\"games\",\"gamesoutlined\",\"smarttoy\",\"smarttoyoutlined\"],\r\n\r\n home: [\"airlineseatindividualsuite\", \"airlineseatindividualsuiteoutlined\", \"apartment\",\"balcony\",\"bed\",\"bedroomchild\",\"bedroomchildoutlined\",\"bedroomparent\",\"bedroomparentoutlined\",\"weekendoutlined\",\"weekend\",\"wbincandescentoutlined\",\"wbincandescent\",\"waterdamageoutlined\",\"waterdamage\",\"villaoutlined\",\"villa\",\"tungstenoutlined\",\"tungsten\",\"bungalow\",\"bungalowoutlined\",\"business\",\"cabin\",\"chair\",\"chairoutlined\",\"chairalt\",\"chalet\",\"chaletoutlined\",\"corporatefare\",\"cottage\",\"cottageoutlined\",\"countertops\",\"countertopsoutlined\",\"domain\",\"domaindisabled\",\"doorback\",\"doorbell\",\"doorbelloutlined\",\"doorfront\",\"doorfrontoutlined\",\"doorsliding\",\"doorslidingoutlined\",\"eventseat\",\"eventseatoutlined\",\"fence\",\"fireplace\",\"fireplaceoutlined\",\"foundation\",\"gite\",\"holidayvillage\",\"holidayvillageoutlined\",\"home\",\"homemax\",\"homemini\",\"homeoutlined\",\"homework\",\"homeworkoutlined\",\"house\",\"houseboat\",\"houseboatoutlined\",\"houseoutlined\",\"housesiding\",\"hvac\",\"hvacoutlined\",\"kingbed\",\"kingbedoutlined\",\"kitchen\",\"living\",\"livingoutlined\",\"localconveniencestore\",\"localconveniencestoreoutlined\",\"locationcity\",\"mapshomework\",\"mapshomeworkoutlined\",\"meetingroom\",\"microwave\",\"microwaveoutlined\",\"museum\",\"museumoutlined\",\"nightshelter\",\"nightshelteroutlined\",\"nomeetingroom\",\"nomeetingroomoutlined\",\"otherhouses\",\"otherhousesoutlined\",\"roofing\",\"roompreferences\",\"roompreferencesoutlined\",\"sensordoor\",\"sensordooroutlined\",\"shower\",\"showeroutlined\",\"singlebed\",\"stairs\",\"stairsoutlined\",\"store\",\"storefront\",\"storeoutlined\",\"humidityindoor\",\"waterpump\",\"walllamp\",\"windowsensor\",\"tablelamp\",\"movingbeds\"],\r\n health:[\"wheelchairpickup\",\"washoutlined\",\"wash\",\"thermostatauto\",\"thermostat\",\"cleanhands\",\"cleanhandsoutlined\",\"cleaningservices\",\"cleaningservicesoutlined\",\"coronavirus\",\"coronavirusoutlined\",\"devicethermostat\",\"healing\",\"healthandsafety\",\"healthandsafetyoutlined\",\"localpharmacy\",\"localpharmacyoutlined\",\"masks\",\"masksoutlined\",\"medicalservices\",\"medicalservicesoutlined\",\"medication\",\"medicationoutlined\",\"monitorweight\",\"monitorweightoutlined\",\"sanitizer\",\"sanitizeroutlined\",\"sick\",\"sickoutlined\",\"soap\",\"soapoutlined\",\"monitorheart\",\"vaccines\",\"radiology\",\"rheumatology\",\"orthopedics\",\"tibia\",\"skeleton\",\"footbones\",\"cognition\",\"tibiaalt\",\"ulnaradius\",\"neurology\",\"ulnaradiusalt\",\"stethoscope\",\"microbiology\",\"pulmonology\",\"nephrology\",\"stethoscopecheck\",\"bloodpressure\",\"stethoscopearrow\",\"mixturemed\",\"ophthalmology\",\"gastroenterology\",\"gynecology\",\"immunology\",\"oncology\",\"respiratoryrate\",\"syringe\",\"adminmeds\",\"endocrinology\",\"procedure\",\"surgical\",\"fluidmed\",\"medicalmask\",\"outpatientmed\",\"pilloff\",\"urology\"],\r\n hand:[\"dry\",\"dryoutlined\",\"pantool\",\"pantooloutlined\",\"swipe\",\"swipeoutlined\"],\r\n\r\n link: [\"addlink\"],\r\n location: [\"addlocation\", \"addlocationoutlined\", \"addlocationalt\", \"addlocationaltoutlined\",\"wronglocationoutlined\",\"wronglocation\",\"wheretovoteoutlined\",\"wheretovote\",\"editlocation\",\"editlocationalt\",\"editlocationaltoutlined\",\"editlocationoutlined\",\"explore\",\"exploreoff\",\"exploreoffoutlined\",\"exploreoutlined\",\"fmdgood\",\"fmdgoodoutlined\",\"locationoff\",\"locationoffoutlined\",\"locationon\",\"locationonoutlined\",\"map\",\"mapoutlined\",\"notlistedlocationoutlined\",\"notlistedlocation\",\"place\",\"placeoutlined\",\"room\",\"roomoutlined\",\"sharelocation\"],\r\n line:[\"viewheadline\",\"toc\",\"texture\",\"calendarviewday\",\"calendarviewdayoutlined\",\"clearall\",\"draghandle\",\"filterline\",\"filterlist\",\"formataligncenter\",\"formatalignjustify\",\"formatalignleft\",\"formatalignright\",\"formatindentdecrease\",\"formatindentincrease\",\"formatlinespacing\",\"formatlistbulleted\",\"formatlistnumbered\",\"formatlistnumberedrtl\",\"formatstrikethrough\",\"graphiceq\",\"horizontalrule\",\"horizontalsplit\",\"legendtoggle\",\"linearscale\",\"linestyle\",\"lineweight\",\"list\",\"listalt\",\"looks\",\"maximize\",\"menu\",\"menuopen\",\"minimize\",\"playlistplay\",\"powerinput\",\"readmore\",\"segment\",\"sort\",\"storage\",\"subject\",\"tablerows\",\"tablerowsoutlined\"],\r\n language:[\"translate\",\"closedcaption\",\"closedcaptiondisabled\",\"closedcaptiondisabledoutlined\",\"closedcaptionoutlined\",\"emobiledata\",\"explicit\",\"explicitoutlined\",\"fontdownload\",\"fontdownloadoff\",\"fontdownloadoffoutlined\",\"fontdownloadoutlined\",\"formatbold\",\"formatclear\",\"formatcolortext\",\"formatitalic\",\"formatquote\",\"formatquoteoutlined\",\"formatshapes\",\"formatsize\",\"formattextdirectionltor\",\"formattextdirectionltoroutlined\",\"formattextdirectionrtol\",\"formattextdirectionrtoloutlined\",\"formatunderlined\",\"gmobiledata\",\"gtranslate\",\"gtranslateoutlined\",\"hdrauto\",\"hdrautooutlined\",\"hmobiledata\",\"hplusmobiledata\",\"http\",\"localparking\",\"motionphotosauto\",\"motionphotosautooutlined\",\"rmobiledata\",\"rtt\",\"sortbyalpha\",\"spellcheck\",\"strikethroughs\",\"autofpsselect\",\"wbautooutlined\",\"wbauto\",\"brightnessauto\",\"brightnessautooutlined\",\"sortbyalpha\",\"abc\"],\r\n light:[\"flashlightoff\",\"flashlightoffoutlined\",\"flashlighton\",\"flashlightonoutlined\",\"flashoff\",\"flashon\",\"flourescent\",\"flourescentoutlined\",\"highlight\",\"highlightoutlined\",\"light\",\"lightbulb\",\"lightbulboutlined\"],\r\n\r\n money: [\"accounbalance\", \"accountbalanceoutlined\", \"accountbalancewallet\",\"accountbalancewalletoutlined\",\"atm\",\"attachmoney\",\"creditcard\",\"creditcardoff\",\"creditcardoffoutlined\",\"creditscore\",\"euro\",\"localatm\",\"monetizationon\",\"monetizationonoutlined\",\"money\",\"moneyoff\",\"paid\",\"paidoutlined\",\"payment\",\"payments\",\"paymentsoutlined\",\"pointofsale\",\"pricechange\",\"pricechangoutlined\",\"pricecheck\",\"requestpage\",\"requestpageoutlined\",\"requestquote\",\"requestquoteoutlined\",\"savings\",\"savingsoutlined\"],\r\n music: [\"album\", \"albumoutlined\",\"audiotrack\",\"audiotrackoutlined\"],\r\n math: [\"architecture\",\"calculate\",\"calculateoutlined\",\"exposure\",\"exposureoutlined\",\"filter1\",\"filter2\",\"filter3\",\"filter4\",\"filter5\",\"filter6\",\"filter7\",\"filter8\",\"filter9\",\"filter9plus\",\"flaky\",\"functions\",\"iso\",\"looks3\",\"looks3outlined\",\"looks4\",\"looks4outlined\",\"looks5\",\"looks5outlined\",\"looks6\",\"looks6outlined\",\"looksone\",\"looksoneoutlined\",\"lookstwo\",\"lookstwooutlined\",\"password\",\"plusone\",\"straighten\",\"subscript\",\"superscript\"],\r\n media: [\"youtube\",\"whatsapp\",\"twitter\",\"telegram\",\"facebook\",\"facebookoutlined\",\"github\",\"google\",\"instagram\",\"linkedin\",\"x\",\"tiktok\",\"snapchat\",\"threads\",\"messenger\", \"qq\", \"pinterest\", \"myspace\", \"medium\", \"reddit\", \"spotify\", \"slack\", \"skype\", \"teams\", \"twitch\", \"thumbler\", \"viber\", \"wechat\", \"vk\", \"amazon\", \"behance\", \"dribble\", \"discord\", \"deviantart\", \"line\"],\r\n measurnment:[\"eightk\",\"eightkoutlined\",\"eightkplus\",\"eightkplusoutlined\",\"eightmp\",\"eightmpoutlined\",\"eightteenmp\",\"eightteenmpoutlined\",\"elevenmp\",\"elevenmpoutlined\",\"fiberdvr\",\"fiberdvroutlined\",\"fibernew\",\"fibernewoutlined\",\"fiberpin\",\"fiberpinoutlined\",\"fiveg\",\"fivek\",\"fivekoutlined\",\"fivekplus\",\"fivekplusoutlined\",\"fivemp\",\"fivempoutlined\",\"fivteenmp\",\"fivteenmpoutlined\",\"fourgmobiledata\",\"fourgplusmobiledata\",\"fourk\",\"fourkoutlined\",\"fourkplus\",\"fourkplusoutlined\",\"fourmp\",\"fourmpoutlined\",\"fourteenmp\",\"fourteenmpoutlined\",\"gif\",\"hd\",\"hdoutlined\",\"hdrautoselect\",\"hdrenhancedselect\",\"hdroff\",\"hdroffselect\",\"hdron\",\"hdronselect\",\"hdrplus\",\"hdrplusoutlined\",\"hevc\",\"highquality\",\"highqualityoutlined\",\"lteplusmobiledata\",\"mp\",\"mpoutlined\",\"ninek\",\"ninekoutlined\",\"ninekplus\",\"ninekplusoutlined\",\"ninemp\",\"ninempoutlined\",\"nineteenmp\",\"nineteenmpoutlined\",\"onek\",\"onekk\",\"onekkoutlined\",\"onekoutlined\",\"onekplus\",\"onekplusoutlined\",\"rawoff\",\"rawon\",\"rsvp\",\"score\",\"scoreoutlined\",\"sd\",\"sdoutlined\",\"sevenk\",\"sevenkoutlined\",\"sevenkplus\",\"sevenkplusoutlined\",\"sevenmp\",\"sevenmpoutlined\",\"seventeenmp\",\"seventeenmpoutlined\",\"sip\",\"sipoutlined\",\"sixk\",\"sixkoutlined\",\"sixkplus\",\"sixkplusoutlined\",\"sixmp\",\"sixmpoutlined\",\"sixteenmp\",\"sixteenmpoutlined\",\"twompoutlined\",\"twomp\",\"twokplusoutlined\",\"twokplus\",\"twokoutlined\",\"twok\",\"twentyzerompoutlined\",\"twentyzeromp\",\"twentytwompoutlined\",\"twentytwomp\",\"twentythreempoutlined\",\"twentythreemp\",\"twentyonempoutlined\",\"twentyonemp\",\"twentyfourmpoutlined\",\"twentyfourmp\",\"twelvempoutlined\",\"twelvemp\",\"threempoutlined\",\"threemp\",\"threekplusoutlined\",\"threekplus\",\"threekoutlined\",\"threek\",\"thirteenmpoutlined\",\"thirteenmp\",\"tenmpoutlined\",\"tenmp\",],\r\n medal:[\"militarytech\",\"militarytechoutlined\"],\r\n move:[\"moveup\",\"movedown\",\"pinch\"],\r\n\r\n\r\n nature:[\"terrainoutlined\",\"terrain\",\"emojinature\",\"emojinatureoutlined\",\"filterhdr\",\"filterhdroutlined\",\"filtervintageoutlined\",\"grass\",\"landscape\",\"landscapeoutlined\",\"localflorist\",\"localfloristoutlined\",\"nature\",\"natureoutlined\",\"naturepeople\",\"naturepeopleoutlined\",\"park\",\"parkoutlined\",\"satellite\",\"satelliteoutlined\",\"spa\",\"spaoutlined\",\"yardoutlined\",\"yard\",\"agriculture\", \"agricultureoutlined\",\"compost\",\"landslide\",\"psychiatry\",\"nutrition\",\"raven\"],\r\n numbers:[\"timesonemobiledata\",\"timer10select\",\"timer10\",\"timer3select\",\"timer3\",\"threegmobiledata\",\"thirtyfpsselect\",\"thirtyfps\",\"tag\",\"sixtyfps\",\"sixtyfpsselect\"],\r\n notification:[\"circlenotifications\",\"circlenotificationsoutlined\",\"editnotifications\",\"editnotificationsoutlined\",\"notificationadd\",\"notificationaddoutlined\",\"notificationimportant\",\"notificationimportantoutlined\",\"notifications\",\"notificationsactive\",\"notificationsactiveoutlined\",\"notificationsoff\",\"notificationsoffoutlined\",\"notificationsoutlined\",\"notificationspaused\",\"notificationspausedoutlined\"],\r\n\r\n photo: [\"addphoto\",\"addphotooutlined\", \"addphotoalternate\", \"addphotoalternateoutlined\", \"addtophotos\", \"addtophotosoutlined\",\"arttrack\",\"wallpaper\",\"vrpaclassic\",\"vrpano\",\"voicechatoutlined\",\"voicechat\",\"videosettings\",\"videolibraryoutlined\",\"videolibrary\",\"videocamerafrontoutlined\",\"videocamerafront\",\"videocamerabackoutlined\",\"videocameraback\",\"videocamoffoutlined\",\"videocamoff\",\"videocamoutlined\",\"videocam\",\"videocalloutlined\",\"videocall\",\"brokenimage\",\"brokenimageoutlined\",\"burstmode\",\"burstmodeoutlined\",\"camera\",\"cameraalt\",\"cameraaltoutlined\",\"cameraenhance\",\"cameraenhanceoutlined\",\"camerafront\",\"camerafrontoutlined\",\"cameraindoor\",\"cameraindooroutlined\",\"cameraoutdoor\",\"cameraoutdooroutlined\",\"cameraoutlined\",\"camerarear\",\"camerarearoutlined\",\"cameraroll\",\"camerarolloutlined\",\"cameraswitch\",\"cameraswitchoutlined\",\"collections\",\"collectionsoutlined\",\"compare\",\"croporiginal\",\"dirtylens\",\"dirtylensoutlined\",\"duo\",\"filter\",\"flipcameraios\",\"flipcameraiosoutlined\",\"hideimage\",\"hideimageoutlined\",\"image\",\"imagenotsupported\",\"imagenotsupportedoutlined\",\"imageoutlined\",\"imagesearch\",\"linkedcamera\",\"linkedcameraoutlined\",\"localmovies\",\"localmoviesoutlined\",\"missedvideocall\",\"missedvideocalloutlined\",\"mms\",\"mmsoutlined\",\"monochromephotos\",\"movie\",\"movie\",\"moviefilteroutlined\",\"movieoutlined\",\"noflash\",\"noflashoutlined\",\"nophotography\",\"nophotographyoutlined\",\"notstarted\",\"notstartedoutlined\",\"panorama\",\"panoramaoutlined\",\"partymode\",\"partymodeoutlined\",\"pause\",\"pausecircle\",\"pausecircleoutlined\",\"pausepresentation\",\"permcameramic\",\"permcameramicoutlined\",\"permmedia\",\"permmediaoutlined\",\"photo\",\"photoalbum\",\"photoalbumoutlined\",\"photocamera\",\"photocameraback\",\"photocamerabackoutlined\",\"photocamerafront\",\"photocamerafrontoutlined\",\"photocameraoutlined\",\"photofilter\",\"photolibrary\",\"photolibraryoutlined\",\"photooutlined\",\"photosizeselectactual\",\"photosizeselectactualoutlined\",\"photosizeselectlarge\",\"photosizeselectsmall\",\"slideshow\",\"subscriptions\",\"subscriptionsoutlined\",\"switchcamera\",\"switchcameraoutlined\",\"switchvideo\",\"switchvideooutlined\"],\r\n phone: [\"addiccall\", \"addiccalloutlined\", \"addtohomescreen\", \"adunits\",\"adunitsoutlined\", \"aod\", \"aodoutlined\", \"appblocking\", \"appblockingoutlined\", \"appsettingsalt\", \"appsettingsaltoutlined\",\"bookonline\",\"bookonlineoutlined\",\"wificallingoutlined\",\"wificalling3outlined\",\"wificalling3\",\"wificalling\",\"vibration\",\"ttyoutlined\",\"tty\",\"tapandplay\",\"call\",\"calloutlined\",\"chargingstation\",\"chargingstationoutlined\",\"contactphone\",\"contactphoneoutlined\",\"deviceunknown\",\"dialersip\",\"dialersipoutlined\",\"dialpad\",\"dock\",\"edgesensorhigh\",\"edgesensorhighoutlined\",\"edgesensorlow\",\"edgesensorlowoutlined\",\"filtervintage\",\"filtervintageoutlined\",\"hotel\",\"hoteloutlined\",\"hottub\",\"importantdevices\",\"mobilefriendly\",\"mobileoff\",\"mobilescreenshare\",\"nocell\",\"nocelloutlined\",\"offlineshare\",\"offlineshareoutlined\",\"pattern\",\"permdeviceinformation\",\"permdeviceinformationoutlined\",\"permphonemsg\",\"permphonemsgoutlined\",\"phone\",\"phoneandroid\",\"phoneandroidoutlined\",\"phonebluetoothspeaker\",\"phonebluetoothspeakeroutlined\",\"phonecallback\",\"phonecallbackoutlined\",\"phonedisabled\",\"phonedisabledoutlined\",\"phoneenabled\",\"phoneenabledoutlined\",\"phoneforwarded\",\"phoneforwardedoutlined\",\"phoneintalk\",\"phoneintalkoutlined\",\"phoneiphone\",\"phonelink\",\"phonelinkerase\",\"phonelinklock\",\"phonelinkoff\",\"phonelinkring\",\"phonelinksetup\",\"phonelinksetupoutlined\",\"phonelocked\",\"phonelockedoutlined\",\"phonemissed\",\"phonemissedoutlined\",\"phoneoutlined\",\"phonepaused\",\"phonepausedoutlined\",\"rememberme\",\"remembermeoutlined\",\"ringvolume\",\"ringvolumeoutlined\",\"screenlocklandscape\",\"screenlockportrait\",\"screenlockrotation\",\"screenrotation\",\"screenshot\",\"screenshotoutlined\",\"securityupdate\",\"securityupdategood\",\"securityupdategoodoutlined\",\"securityupdateoutlined\",\"securityupdatewarning\",\"securityupdatewarningoutlined\",\"sendtomobile\",\"sendtomobileoutlined\",\"settingscell\",\"settingscelloutlined\",\"settingsphone\",\"settingsphoneoutlined\",\"smartphone\",\"smartscreen\",\"smartscreenoutlined\",\"speakerphone\",\"staycurrentlandscape\",\"staycurrentportrait\",\"style\",\"styleoutlined\",\"systemsecurityupdate\",\"systemsecurityupdategood\",\"systemsecurityupdategoodoutlined\",\"systemsecurityupdateoutlined\",\"systemsecurityupdatewarning\",\"systemsecurityupdatewarningoutlined\",\"systemupdate\",\"tablet\",\"tabletandroid\",\"tabletmac\"],\r\n plane: [\"airlineeeatflat\", \"airlineseatflatoutlined\", \"airlineseatflatangled\", \"airlineseatflatangledoutlined\", \"airplanemodeactive\", \"airplanemodeinactive\", \"airplaneticket\", \"airplaneticketoutlined\",\"flight\",\"flightland\",\"flighttakeoff\"],\r\n politics: [\"ballot\",\"ballotoutlined\",\"howtovote\",\"howtovoteoutlined\"],\r\n person:[\"directionsrun\",\"directionswalk\",\"elderly\",\"elevator\",\"elevatoroutlined\",\"emojipeople\",\"engineering\",\"engineeringoutlined\",\"escalatorwarning\",\"face\",\"faceoutlined\",\"faceretouchingnatural\",\"faceretouchingnaturaloutlined\",\"faceretouchingoff\",\"faceretouchingoffoutlined\",\"familyrestroom\",\"female\",\"fingerprint\",\"followthesigns\",\"group\",\"groupadd\",\"groupaddoutlined\",\"groups\",\"groupsoutlined\",\"hail\",\"male\",\"people\",\"peoplealt\",\"peoplealtoutlined\",\"peopleoutline\",\"peopleoutlined\",\"permcontactcalendar\",\"permcontactcalendaroutlined\",\"person\",\"personadd\",\"personaddalt1\",\"personaddalt1outlined\",\"personadddisabled\",\"personadddisabledoutlined\",\"personaddoutlined\",\"personoutlined\",\"personoff\",\"personoffoutlined\",\"personpin\",\"personpincircle\",\"personpincircleoutlined\",\"personpinoutlined\",\"personremove\",\"personremoveoutlined\",\"personsearch\",\"personsearchoutlined\",\"pregnantwoman\",\"presenttoall\",\"reducecapacity\",\"runcircle\",\"runcircleoutlined\",\"safetydivider\",\"selfimprovement\",\"settingsaccessibility\",\"socialdistance\",\"supervisedusercircle\",\"supervisedusercircleoutlined\",\"supervisoraccount\",\"supervisoraccountoutlined\",\"supportagent\",\"wc\",\"transferwithinastation\",\"zonepersonidle\",\"personraisedhand\"],\r\n pen:[\"edit\",\"editoutlined\",\"editoff\",\"editoffoutlined\"],\r\n print:[\"print\",\"printdisabled\",\"printdisabledoutlined\",\"printoutlined\"],\r\n programming:[],\r\n\r\n question:[\"contactsupport\",\"contactsupportoutlined\",\"help\",\"helpcenter\",\"helpcenteroutlined\",\"helpoutlined\",\"livehelp\",\"livehelpoutlined\",\"quiz\",\"quizoutlined\"],\r\n qr:[\"qrcode\",\"qrcode2\",\"qrcodescanner\"],\r\n\r\n security: [\"addmoderator\", \"addmoderatoroutlined\",\"adminpanelsettings\", \"adminpanelsettingsoutlined\",\"visibilityoutlined\",\"visibilityoffoutlined\",\"visibilityoff\",\"visibility\",\"enhancedencryption\",\"enhancedencryptionoutlined\",\"gppbad\",\"gppbadoutlined\",\"gppgood\",\"gppgoodoutlined\",\"gppmaybe\",\"gppmaybeoutlined\",\"https\",\"httpsoutlined\",\"localpolice\",\"localpoliceoutlined\",\"lock\",\"lockclock\",\"lockclockoutlined\",\"lockopen\",\"lockoutlined\",\"noencryption\",\"noencryptiongmailerrorred\",\"noencryptiongmailerrorredoutlined\",\"noencryptionoutlined\",\"policy\",\"policyoutlined\",\"removemoderator\",\"removemoderatoroutlined\",\"security\",\"shield\",\"shieldoutlined\"],\r\n street: [\"addroad\",\"trafficoutlined\",\"traffic\",\"editroad\",\"nearbyerror\",\"nearbyoff\"],\r\n seat: [\"airlineseatlegroomextra\", \"airlineseatlegroomnormal\", \"airlineseatlegroomreduced\", \"airlineseatreclineextra\", \"airlineseatreclinenormal\", \"airlineseatreclinenormaloutlined\"],\r\n \"shapes\": [\"allinclusive\", \"allout\", \"vignetteoutlined\",\"vignette\",\"category\",\"categoryoutlined\",\"changehistory\",\"details\",\"eject\",\"ejectoutlined\",\"filterbandw\",\"networkcell\",\"networklocked\",\"networklockedoutlined\",\"permdatasetting\",\"permdatasettingoutlined\",\"signalcellular0bar\",\"signalcellular1bar\",\"signalcellular2bar\",\"signalcellular3bar\",\"signalcellular4bar\",\"signalcellularalt\",\"signalcellularconnectednointernet\",\"signalcellularconnectednointernetoutlined\",\"signalcellularnodata\",\"signalcellularnull\",\"squarefoot\",\"squarefootoutlined\",\"stopoutlined\",\"streetview\"],\r\n sea: [\"anchor\",\"beachaccess\",\"beachaccessoutlined\",\"waves\",\"water\",\"directionsboat\",\"directionsboatoutlined\",\"kayaking\",\"pool\",\"sailing\",\"sailingoutlined\",\"support\"],\r\n star: [\"autoawesome\",\"autoawesomeoutlined\",\"bedtime\",\"bedtimeoutlined\",\"brightness2\",\"brightness2outlined\",\"brightness3\",\"brightness3outlined\",\"darkmode\",\"darkmodeoutlined\",\"grade\",\"gradeoutlined\",\"modenight\",\"modenightoutlined\",\"nightlight\",\"nightlightoutlined\",\"nightlightround\",\"nightlightroundoutlined\",\"nightsstay\",\"nightsstayoutlined\",\"offers\",\"settingsinputsvideo\",\"star\",\"starborder\",\"starborderpurple500\",\"starborderpurple500outlined\",\"starhalf\",\"starpurple500\",\"starrate\",\"starrateoutlined\",\"stars\",\"starsoutlined\"],\r\n square: [\"checkboxoutlineblank\",\"viewstream\",\"viewdayoutlined\",\"viewday\",\"viewcompactoutlined\",\"viewcompact\",\"viewcomfyoutlined\",\"viewcomfy\",\"viewcolumnoutlined\",\"viewcolumn\",\"viewcarouseloutlined\",\"viewcarousel\",\"viewarray\",\"viewagendaoutlined\",\"viewagenda\",\"videostableoutlined\",\"videostable\",\"viewsidebaroutlined\",\"viewsidebar\",\"viewquiltoutlined\",\"viewquilt\",\"viewmoduleoutlined\",\"viewmodule\",\"viewlistoutlined\",\"viewlist\",\"viewstreamoutlined\",\"viewweek\",\"viewweekoutlined\",\"autoawesomemosaic\",\"autoawesomemosaicoutlined\",\"autoawesomemotion\",\"autoawesomemotionoutlined\",\"backuptable\",\"bento\",\"bentooutlined\",\"borderall\",\"borderbottom\",\"borderclear\",\"bordercolor\",\"bordercoloroutlined\",\"borderhorizontal\",\"borderinner\",\"borderleft\",\"borderouter\",\"borderright\",\"borderstyle\",\"bordertop\",\"bordervertical\",\"brandingwatermark\",\"brandingwatermarkoutlined\",\"window\",\"widgetsoutlined\",\"widgets\",\"webassetoff\",\"webasset\",\"web\",\"videolabel\",\"verticalsplitoutlined\",\"verticalsplit\",\"tabunselected\",\"tableview\",\"browsernotsupported\",\"calendarviewmonth\",\"calendarviewweek\",\"calltoaction\",\"calltoactionoutlined\",\"cardmembership\",\"casino\",\"centerfocusstrong\",\"centerfocusstrongoutlined\",\"contentcopy\",\"copyall\",\"crop\",\"crop32\",\"crop54\",\"crop75\",\"crop169\",\"cropdin\",\"cropfree\",\"croplandscape\",\"cropportrait\",\"croprotate\",\"cropsquare\",\"dashboard\",\"dashboardoutlined\",\"dns\",\"dnsoutlined\",\"dynamicfeed\",\"dynamicform\",\"dynamicformoutlined\",\"featuredvideo\",\"featuredvideooutlined\",\"filtercenterfocus\",\"filterframes\",\"filterframesoutlined\",\"filternone\",\"fitscreen\",\"fitscreenoutlined\",\"flip\",\"fliptoback\",\"fliptofront\",\"fullscreen\",\"fullscreenexit\",\"grid3x3\",\"grid4x4\",\"gridgoldenratio\",\"gridoff\",\"gridon\",\"gridview\",\"highlightalt\",\"historyedu\",\"imageaspectratio\",\"layers\",\"layersclear\",\"layersclearoutlined\",\"layersoutlined\",\"margin\",\"padding\",\"pages\",\"pagesoutlined\",\"panoramahorizontal\",\"panoramahorizontalselect\",\"panoramavertical\",\"panoramaverticalselect\",\"panoramawideangle\",\"panoramawideangleselect\",\"repeaton\",\"repeatoneon\",\"roundedcorner\",\"selectall\",\"sensorwindow\",\"sensorwindowoutlined\",\"settingsoverscan\",\"shuffleon\",\"smartbutton\",\"spacebar\",\"splitscreen\",\"stop\",\"stopoutlined\",\"subtitles\",\"subtitlesoff\",\"subtitlesoffoutlined\",\"subtitlesoutlined\"],\r\n science: [\"biotech\",\"biotechoutlined\", \"bloodtype\",\"bloodtypeoutlined\",\"psychology\",\"psychologyoutlined\",\"science\",\"scienceoutlined\"],\r\n sound:[\"volumeupoutlined\",\"volumeup\",\"volumeoffoutlined\",\"volumeoff\",\"volumemuteoutlined\",\"volumemute\",\"volumedownoutlined\",\"volumedown\",\"voiceoveroffoutlined\",\"voiceoveroff\",\"voicemail\",\"campaign\",\"campaignoutlined\",\"earbuds\",\"earbudsbattery\",\"earbudsoutlined\",\"headphones\",\"headphonesoutlined\",\"headset\",\"headsetmic\",\"headsetmicoutlined\",\"headsetoff\",\"headsetoffoutlined\",\"headsetoutlined\",\"hearing\",\"hearingdisabled\",\"keyboardvoice\",\"keyboardvoiceoutlined\",\"leakadd\",\"leakremove\",\"librarymusic\",\"librarymusicoutlined\",\"mediabluetoothoff\",\"mediabluetoothon\",\"mic\",\"micexternaloff\",\"micexternaloffoutlined\",\"micexternalon\",\"micexternalonoutlined\",\"micnone\",\"micoff\",\"micoffoutlined\",\"musicnote\",\"musicnoteoutlined\",\"musicoff\",\"musicoffoutlined\",\"musicvideo\",\"podcasts\",\"queuemusic\",\"radio\",\"recordvoiceover\",\"recordvoiceoveroutlined\",\"settingsvoice\",\"settingsvoiceoutlined\",\"speaker\",\"speakeroutlined\",\"speakergroup\",\"speakergroupoutlined\",\"surroundsound\",\"surroundsoundoutlined\"],\r\n safety:[\"fireextinguisher\"],\r\n sport:[\"fitnesscenter\",\"hiking\",\"iceskating\",\"iceskatingoutlined\",\"kitesurfing\",\"nordicwalking\",\"paragliding\",\"paraglidingoutlined\",\"rowing\",\"skateboarding\",\"sledding\",\"snowboarding\",\"snowmobile\",\"snowmobileoutlined\",\"snowshoeing\",\"sports\",\"sportsbaseball\",\"sportsbaseballoutlined\",\"sportsbasketball\",\"sportsbasketballoutlined\",\"sportscricket\",\"sportscricketoutlined\",\"sportsesports\",\"sportsesportsoutlined\",\"sportsfootball\",\"sportsfootballoutlined\",\"sportsgolf\",\"sportshandball\",\"sportshockey\",\"sportskabaddi\",\"sportsmma\",\"sportsmmaoutlined\",\"sportsmotorsports\",\"sportsmotorsportsoutlined\",\"sportsrugby\",\"sportsrugbyoutlined\",\"sportsscore\",\"sportssoccer\",\"sportstennis\",\"sportsvolleyball\",\"sportsvolleyballoutlined\",\"surfing\"],\r\n settings:[\"miscellaneousservices\",\"settings\",\"settingsapplications\",\"settingsapplicationsoutlined\",\"settingsoutlined\",\"settingssuggest\",\"settingssuggestoutlined\"],\r\n smoke:[\"smokefree\",\"smokingrooms\"],\r\n space:[\"rocket\"],\r\n\r\n task: [\"addtask\",\"pendingactions\"],\r\n time: [\"accesstime\", \"accesstimefilled\",\"addalarm\", \"alarm\", \"alarmadd\", \"alarmoff\", \"alarmon\",\"avtimer\",\"watchlateroutlined\",\"watchoutlined\",\"watchlater\",\"watch\",\"timeroff\",\"timer\",\"historytoggleoff\",\"hourglassbottom\",\"hourglassdisabled\",\"hourglassempty\",\"hourglassfull\",\"hourglasstop\",\"moretime\",\"schedule\",\"shutterspeed\",\"snooze\",\"history\"], \r\n tempreature: [\"acnitu\", \"air\", \"airoutlined\",\"bolt\",\"whatshotoutlined\",\"whatshot\",\"wbtwilight\",\"wbsunnyoutlined\",\"wbsunny\",\"wbshade\",\"wbcloudyoutlined\",\"wbcloudy\",\"brightness4\",\"brightness4outlined\",\"brightnesshigh\",\"brightnesshighoutlined\",\"brightnesslow\",\"brightnesslowoutlined\",\"brightnessmedium\",\"brightnessmediumoutlined\",\"cloud\",\"cloudcircle\",\"cloudcircleoutlined\",\"cloudoff\",\"cloudoutlined\",\"filterdrama\",\"flare\",\"flashauto\",\"lightmode\",\"lightmodeoutlined\",\"localfiredepartment\",\"offlinebolt\",\"offlineboltoutlined\",\"settingsbrightness\",\"settingssystemdaydream\",\"settingssystemdaydreamoutlined\",\"storm\",\"modedual\", \"solarpanel\"],\r\n technology: [\"adb\", \"addtodrive\", \"addtodriveoutlined\", \"addtoqueue\", \"airplay\", \"android\", \"api\", \"apple\", \"appregistration\", \"approval\", \"apps\",\"bluetooth\",\"bluetoothaudio\",\"bluetoothconnected\",\"bluetoothdisabled\",\"wifitetheringoff\",\"wifitethering\",\"wifiprotectedsetup\",\"wifioff\",\"wifilock\",\"wifi\",\"vpnkeyoutlined\",\"vpnkey\",\"usboff\",\"usb\",\"tvoff\",\"tv\",\"toggleonoutlined\",\"toggleon\",\"toggleoffoutlined\",\"bugreport\",\"bugreportoutlined\",\"cast\",\"castconnected\",\"castconnectedoutlined\",\"castforeducation\",\"castforeducationoutlined\",\"cellwifi\",\"code\",\"codeoff\",\"computer\",\"connectedtv\",\"connectwithoutcontact\",\"copyright\",\"desktopaccessdisabled\",\"desktopmac\",\"desktopwindows\",\"developerboard\",\"developerboardoff\",\"devices\",\"devicesother\",\"electricalservices\",\"keyboard\",\"keyboardalt\",\"keyboardaltoutlined\",\"keyboardhide\",\"keyboardhideoutlined\",\"memory\",\"mouseoutlined\",\"networkcheck\",\"networkwifi\",\"nosim\",\"nosimoutlined\",\"onlineprediction\",\"permscanwifi\",\"permscanwifioutlined\",\"pestcontrol\",\"pestcontroloutlined\",\"portablewifioff\",\"power\",\"poweroff\",\"poweroffoutlined\",\"poweroutlined\",\"powersettingsnew\",\"reddit\",\"router\",\"routeroutlined\",\"rssfeed\",\"scanner\",\"scanneroutlined\",\"sdcard\",\"sdcardoutlined\",\"sdstorage\",\"sdstorageoutlined\",\"sensors\",\"sensorsoff\",\"settingsinputantenna\",\"settingsinputcomponent\",\"settingsinputcomponentoutlined\",\"settingsinputhdmi\",\"settingsinputhdmioutlined\",\"settingspower\",\"settingsremote\",\"settingsremoteoutlined\",\"signalcellularnosim\",\"signalcellularnosimoutlined\",\"signalcellularoff\",\"signalwifi0bar\",\"signalwifi1bar\",\"signalwifi1barlock\",\"signalwifi2bar\",\"signalwifi2barlock\",\"signalwifi3bar\",\"signalwifi3barlock\",\"signalwifi4bar\",\"signalwifi4barlock\",\"signalwifibad\",\"signalwifioff\",\"signalwifistatusbar4bar\",\"signalwifistatusbarconnectednointernet\",\"signalwifistatusbarnull\",\"simcard\",\"simcardalert\",\"simcardalertoutlined\",\"simcarddownload\",\"simcarddownloadoutlined\",\"simcardoutlined\",\"compasscalibration\",\"compasscalibrationoutlined\",\"confirmationnumber\",\"confirmationnumberoutlined\",\"flutterdash\",\"localactivity\",\"localactivityoutlined\",\"nfc\",\"dynamicform\",\"keyboardcommandkey\",\"php\",\"sendtimeextension\",\"extensionoff\"],\r\n text: [\"article\", \"articleoutlined\",\"assignment\",\"assignmentoutlined\",\"wysiwyg\",\"wraptext\",\"topicoutlined\",\"topic\",\"title\",\"textsnippetoutlined\",\"textsnippet\",\"textsmsoutlined\",\"textsms\",\"textrotationnone\",\"textrotationdown\",\"textrotationangleup\",\"textrotationangledown\",\"textrotatevertical\",\"textrotateup\",\"textformat\",\"textfields\",\"chat\",\"chatoutlined\",\"chatbubble\",\"chatbubbleoutlined\",\"chromereadermode\",\"chromereadermodeoutlined\",\"comment\",\"commentoutlined\",\"description\",\"descriptionoutlined\",\"documentscanneroutlined\",\"documentscannerrounded\",\"dvr\",\"featuredplaylist\",\"featuredplaylistoutlined\",\"feed\",\"feedoutlined\",\"grading\",\"insertcomment\",\"insertcommentoutlined\",\"librarybooks\",\"librarybooksoutlined\",\"message\",\"messageoutlined\",\"postadd\",\"shorttext\",\"source\",\"speakernotes\",\"speakernotesoff\",\"speakernotesoffoutlined\",\"speakernotesoutlined\",\"stickynote2\",\"stickynote2outlined\"],\r\n tool:[\"build\",\"buildoutlined\",\"buildcircle\",\"buildcircleoutlined\",\"carpenter\",\"carpenteroutlined\",\"colorize\",\"colorizeoutlined\",\"construction\",\"contactless\",\"contactlessoutlined\",\"contentcut\",\"create\",\"createoutlined\",\"designservices\",\"designservicesoutlined\",\"drivefilerenameoutline\",\"emojiobjects\",\"emojiobjectsoutlined\",\"emojisymbols\",\"filteralt\",\"filteraltoutlined\",\"formatcolorfill\",\"formatcolorreset\",\"formatcolorresetoutlined\",\"formatpaint\",\"formatpaintoutlined\",\"gavel\",\"handyman\",\"handymanoutlined\",\"hardware\",\"hardwareoutlined\",\"imagesearchroller\",\"imagesearchrolleroutlined\",\"plumbing\",\"precisionmanufacturing\",\"precisionmanufacturingoutlined\",\"pushpin\",\"pushpinoutlined\", \"scissors\"],\r\n target:[\"gpsfixed\",\"gpsnotfixed\",\"gpsoff\"],\r\n tag:[\"localoffer\",\"localofferoutlined\",\"loyalty\",\"loyaltyoutlined\",\"sell\",\"selloutlined\"],\r\n\r\n upload:[\"backup\",\"backupoutlined\",\"drivefolderupload\",\"drivefolderuploadoutlined\",\"cloudupload\",\"clouduploadoutlined\",\"fileupload\",\"fileuploadoutlined\",\"iosshare\",\"openinbrowser\",\"outbox\",\"outboxoutlined\",\"publish\",\"publishoutlined\"],\r\n\r\n view:[\"laptop\",\"laptopchromebook\",\"laptopmac\",\"laptopwindows\",\"livetv\",\"monitor\",\"ondemandvideo\",\"personalvideo\",\"preview\",\"previewoutlined\",\"queueplaynext\",\"removefromqueue\",\"removeredeye\",\"removeredeyeoutlined\",\"resettv\",\"resettvoutlined\",\"screensearchdesktop\",\"screensearchdesktopoutlined\",\"screenshare\",\"screenshareoutlined\",\"smartdisplay\",\"smartdisplayoutlined\",\"stopscreenshare\",\"stopscreenshareoutlined\",\"tab\"],\r\n\r\n world: [\"vpnlock\",\"travelexplore\",\"language\",\"public\",\"publicoff\"],\r\n\r\n zoom: [\"zoomout\",\"zoomin\",\"youtubesearchedfor\",\"findinpage\",\"findinpageoutlined\",\"findreplace\",\"managesearch\",\"pageview\",\"pageviewoutlined\",\"savedsearch\",\"search\",\"searchalt\",\"searchoff\"],\r\n\r\n };\r\n \r\n export default objIconsCategories;\r\n","\"use client\";\r\n\r\nfunction getPkgConfigIcon() {\r\n const initConfig = {\r\n blnIsTestingMode: true,\r\n };\r\n return initConfig;\r\n }\r\n\r\n export var pkgConfigIcon = getPkgConfigIcon();\r\n\r\n export function setPkgConfigIcon({ blnIsTestingMode = false,}) {\r\n pkgConfigIcon.blnIsTestingMode = blnIsTestingMode;\r\n }\r\n\r\n\r\nexport { default as Icon } from './Icon';\r\nexport {default as objIconsCategories} from \"./iconsCategories\"","// Imports\nimport ___CSS_LOADER_API_SOURCEMAP_IMPORT___ from \"../../../../../node_modules/css-loader/dist/runtime/sourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../../../../../node_modules/css-loader/dist/runtime/api.js\";\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_SOURCEMAP_IMPORT___);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, \".overflowContainer {\\r\\n overflow: hidden;\\r\\n width: 100%; \\r\\n height: 100%; \\r\\n position: relative;\\r\\n}\\r\\n\\r\\n.animation-fadeIn {\\r\\n animation: fadeIn 0.3s forwards;\\r\\n}\\r\\n\\r\\n.animation-fadeOut {\\r\\n animation: fadeOut 0.3s forwards;\\r\\n}\\r\\n\\r\\n.animation-grow {\\r\\n animation: grow 0.3s forwards;\\r\\n}\\r\\n\\r\\n.animation-slideIn {\\r\\n animation: slideIn 0.3s forwards;\\r\\n}\\r\\n\\r\\n.animation-slideOut {\\r\\n animation: slideOut 0.3s forwards;\\r\\n}\\r\\n\\r\\n.animation-rotate {\\r\\n animation: rotate 0.6s forwards;\\r\\n}\\r\\n\\r\\n.animation-slideInRotate {\\r\\n animation: slideInRotate 0.6s forwards;\\r\\n}\\r\\n\\r\\n.animation-slideOutRotate {\\r\\n animation: slideOutRotate 0.6s forwards;\\r\\n}\\r\\n\\r\\n.animation-fadeInGrow {\\r\\n animation: fadeInGrow 0.6s forwards;\\r\\n}\\r\\n\\r\\n.animation-fadeOutGrow {\\r\\n animation: fadeOutGrow 0.6s forwards;\\r\\n}\\r\\n\\r\\n.animation-fadeInSlideIn {\\r\\n animation: fadeInSlideIn 0.6s forwards;\\r\\n}\\r\\n\\r\\n.animation-fadeOutSlideOut {\\r\\n animation: fadeOutSlideOut 0.6s forwards;\\r\\n}\\r\\n\\r\\n.animation-bounce {\\r\\n animation: bounce 0.5s forwards;\\r\\n}\\r\\n\\r\\n.animation-pulse {\\r\\n animation: pulse 0.5s forwards;\\r\\n}\\r\\n\\r\\n.animation-shake {\\r\\n animation: shake 0.5s forwards;\\r\\n}\\r\\n\\r\\n.animation-tada {\\r\\n animation: tada 0.5s forwards;\\r\\n}\\r\\n\\r\\n.animation-flash {\\r\\n animation: flash 0.5s forwards;\\r\\n}\\r\\n\\r\\n.animation-rubberBand {\\r\\n animation: rubberBand 1s forwards;\\r\\n}\\r\\n\\r\\n.animation-swing {\\r\\n animation: swing 1s forwards;\\r\\n}\\r\\n\\r\\n.animation-jello {\\r\\n animation: jello 1s forwards;\\r\\n}\\r\\n\\r\\n.animation-wobble {\\r\\n animation: wobble 1s forwards;\\r\\n}\\r\\n\\r\\n.animation-hinge {\\r\\n animation: hinge 2s forwards;\\r\\n}\\r\\n\\r\\n.animation-flip {\\r\\n animation: flip 0.6s forwards;\\r\\n}\\r\\n\\r\\n.animation-flipInX {\\r\\n animation: flipInX 0.6s forwards;\\r\\n}\\r\\n\\r\\n.animation-flipOutX {\\r\\n animation: flipOutX 0.6s forwards;\\r\\n}\\r\\n\\r\\n.animation-flipInY {\\r\\n animation: flipInY 0.6s forwards;\\r\\n}\\r\\n\\r\\n.animation-flipOutY {\\r\\n animation: flipOutY 0.6s forwards;\\r\\n}\\r\\n\\r\\n.animation-rollIn {\\r\\n animation: rollIn 0.6s forwards;\\r\\n}\\r\\n\\r\\n.animation-rollOut {\\r\\n animation: rollOut 0.6s forwards;\\r\\n}\\r\\n\\r\\n.animation-rotateIn {\\r\\n animation: rotateIn 0.6s forwards;\\r\\n}\\r\\n\\r\\n.animation-rotateOut {\\r\\n animation: rotateOut 0.6s forwards;\\r\\n}\\r\\n\\r\\n.animation-slideInUp {\\r\\n animation: slideInUp 0.6s forwards;\\r\\n}\\r\\n\\r\\n.animation-slideInDown {\\r\\n animation: slideInDown 0.6s forwards;\\r\\n}\\r\\n\\r\\n.animation-slideInLeft {\\r\\n animation: slideInLeft 0.6s forwards;\\r\\n}\\r\\n\\r\\n.animation-slideInRight {\\r\\n animation: slideInRight 0.6s forwards;\\r\\n}\\r\\n\\r\\n.animation-slideOutUp {\\r\\n animation: slideOutUp 0.6s forwards;\\r\\n}\\r\\n\\r\\n.animation-slideOutDown {\\r\\n animation: slideOutDown 0.6s forwards;\\r\\n}\\r\\n\\r\\n.animation-slideOutLeft {\\r\\n animation: slideOutLeft 0.6s forwards;\\r\\n}\\r\\n\\r\\n.animation-slideOutRight {\\r\\n animation: slideOutRight 0.6s forwards;\\r\\n}\\r\\n\\r\\n\\r\\n@keyframes fadeIn {\\r\\n 0% { opacity: 0; }\\r\\n 100% { opacity: 1; }\\r\\n}\\r\\n\\r\\n@keyframes fadeOut {\\r\\n 0% { opacity: 1; }\\r\\n 100% { opacity: 0; }\\r\\n}\\r\\n\\r\\n@keyframes grow {\\r\\n 0% { transform: scale(0); }\\r\\n 100% { transform: scale(1); }\\r\\n}\\r\\n\\r\\n@keyframes slideIn {\\r\\n 0% { transform: translateX(-100%); }\\r\\n 100% { transform: translateX(0); }\\r\\n}\\r\\n\\r\\n@keyframes slideOut {\\r\\n 0% { transform: translateX(0); }\\r\\n 100% { transform: translateX(100%); }\\r\\n}\\r\\n\\r\\n@keyframes rotate {\\r\\n 0% { transform: rotate(0deg); }\\r\\n 100% { transform: rotate(360deg); }\\r\\n}\\r\\n\\r\\n@keyframes slideInRotate {\\r\\n 0% {\\r\\n transform: translateX(-100%) rotate(0deg);\\r\\n }\\r\\n 100% {\\r\\n transform: translateX(0) rotate(360deg);\\r\\n }\\r\\n}\\r\\n\\r\\n@keyframes slideOutRotate {\\r\\n 0% {\\r\\n transform: translateX(0) rotate(0deg);\\r\\n }\\r\\n 100% {\\r\\n transform: translateX(100%) rotate(360deg);\\r\\n }\\r\\n}\\r\\n\\r\\n@keyframes fadeInGrow {\\r\\n 0% {\\r\\n opacity: 0;\\r\\n transform: scale(0);\\r\\n }\\r\\n 100% {\\r\\n opacity: 1;\\r\\n transform: scale(1);\\r\\n }\\r\\n}\\r\\n\\r\\n\\r\\n@keyframes fadeOutGrow {\\r\\n 0% {\\r\\n opacity: 1;\\r\\n transform: scale(1);\\r\\n }\\r\\n 50% {\\r\\n opacity: 0;\\r\\n }\\r\\n 100% {\\r\\n opacity: 0;\\r\\n transform: scale(0);\\r\\n }\\r\\n}\\r\\n\\r\\n@keyframes fadeInSlideIn {\\r\\n 0% {\\r\\n opacity: 0;\\r\\n transform: translateX(-100%);\\r\\n }\\r\\n 50% {\\r\\n opacity: 1;\\r\\n }\\r\\n 100% {\\r\\n opacity: 1;\\r\\n transform: translateX(0);\\r\\n }\\r\\n}\\r\\n\\r\\n@keyframes fadeOutSlideOut {\\r\\n 0% {\\r\\n opacity: 1;\\r\\n transform: translateX(0);\\r\\n }\\r\\n 50% {\\r\\n opacity: 0;\\r\\n }\\r\\n 100% {\\r\\n opacity: 0;\\r\\n transform: translateX(100%);\\r\\n }\\r\\n}\\r\\n\\r\\n@keyframes bounce {\\r\\n 0%, 20%, 50%, 80%, 100% {\\r\\n transform: translateY(0);\\r\\n }\\r\\n 40% {\\r\\n transform: translateY(-20px);\\r\\n }\\r\\n 60% {\\r\\n transform: translateY(-10px);\\r\\n }\\r\\n}\\r\\n\\r\\n@keyframes pulse {\\r\\n 50% {\\r\\n transform: scale(1.05);\\r\\n }\\r\\n}\\r\\n\\r\\n@keyframes shake {\\r\\n 10%, 90% {\\r\\n transform: translateX(-10%);\\r\\n }\\r\\n 20%, 80% {\\r\\n transform: translateX(10%);\\r\\n }\\r\\n 30%, 50%, 70% {\\r\\n transform: translateX(-5%);\\r\\n }\\r\\n 40%, 60% {\\r\\n transform: translateX(5%);\\r\\n }\\r\\n}\\r\\n\\r\\n@keyframes tada {\\r\\n 10%, 20% {\\r\\n transform: scale(0.9) rotate(-3deg);\\r\\n }\\r\\n 30%, 50%, 70%, 90% {\\r\\n transform: scale(1.1) rotate(3deg);\\r\\n }\\r\\n 40%, 60%, 80% {\\r\\n transform: scale(1.1) rotate(-3deg);\\r\\n }\\r\\n}\\r\\n\\r\\n@keyframes flash {\\r\\n 50% {\\r\\n opacity: 0.3;\\r\\n }\\r\\n}\\r\\n\\r\\n@keyframes rubberBand {\\r\\n 30% {\\r\\n transform: scaleX(1.25) scaleY(0.75);\\r\\n }\\r\\n 40% {\\r\\n transform: scaleX(0.75) scaleY(1.25);\\r\\n }\\r\\n 50% {\\r\\n transform: scaleX(1.15) scaleY(0.85);\\r\\n }\\r\\n 65% {\\r\\n transform: scaleX(0.95) scaleY(1.05);\\r\\n }\\r\\n 75% {\\r\\n transform: scaleX(1.05) scaleY(0.95);\\r\\n }\\r\\n}\\r\\n\\r\\n@keyframes swing {\\r\\n 20% {\\r\\n transform: rotate(15deg);\\r\\n }\\r\\n 40% {\\r\\n transform: rotate(-10deg);\\r\\n }\\r\\n 60% {\\r\\n transform: rotate(5deg);\\r\\n }\\r\\n 80% {\\r\\n transform: rotate(-5deg);\\r\\n }\\r\\n}\\r\\n\\r\\n@keyframes jello {\\r\\n 11%, 100% {\\r\\n transform: none;\\r\\n }\\r\\n 22% {\\r\\n transform: skewX(-12.5deg) skewY(-12.5deg);\\r\\n }\\r\\n 33% {\\r\\n transform: skewX(6.25deg) skewY(6.25deg);\\r\\n }\\r\\n 44% {\\r\\n transform: skewX(-3.125deg) skewY(-3.125deg);\\r\\n }\\r\\n 55% {\\r\\n transform: skewX(1.5625deg) skewY(1.5625deg);\\r\\n }\\r\\n 66% {\\r\\n transform: skewX(-0.78125deg) skewY(-0.78125deg);\\r\\n }\\r\\n 77% {\\r\\n transform: skewX(0.390625deg) skewY(0.390625deg);\\r\\n }\\r\\n 88% {\\r\\n transform: skewX(-0.1953125deg) skewY(-0.1953125deg);\\r\\n }\\r\\n}\\r\\n\\r\\n@keyframes wobble {\\r\\n 0% { transform: translateX(0%); }\\r\\n 15% { transform: translateX(-25%) rotate(-5deg); }\\r\\n 30% { transform: translateX(20%) rotate(3deg); }\\r\\n 45% { transform: translateX(-15%) rotate(-3deg); }\\r\\n 60% { transform: translateX(10%) rotate(2deg); } \\r\\n 75% { transform: translateX(-5%) rotate(-1deg); }\\r\\n 100% { transform: translateX(0%); }\\r\\n}\\r\\n\\r\\n@keyframes hinge {\\r\\n 0% { transform: rotate(0); }\\r\\n 20% { transform: rotate(80deg); transform-origin: top left; }\\r\\n 40% { transform: translate(0, 700px); opacity: 1; }\\r\\n 100% { transform: translate(0, 700px); opacity: 0; }\\r\\n}\\r\\n\\r\\n@keyframes flip {\\r\\n 0% { transform: perspective(400px) rotateY(0); }\\r\\n 100% { transform: perspective(400px) rotateY(1turn); }\\r\\n}\\r\\n\\r\\n@keyframes flipInX {\\r\\n 0% { transform: perspective(400px) rotateX(90deg); opacity: 0; }\\r\\n 100% { transform: perspective(400px) rotateX(0deg); opacity: 1; }\\r\\n}\\r\\n\\r\\n@keyframes flipOutX {\\r\\n 0% { transform: perspective(400px) rotateX(0deg); opacity: 1; }\\r\\n 100% { transform: perspective(400px) rotateX(90deg); opacity: 0; }\\r\\n}\\r\\n\\r\\n@keyframes flipInY {\\r\\n 0% { transform: perspective(400px) rotateY(90deg); opacity: 0; }\\r\\n 100% { transform: perspective(400px) rotateY(0deg); opacity: 1; }\\r\\n}\\r\\n\\r\\n@keyframes flipOutY {\\r\\n 0% { transform: perspective(400px) rotateY(0deg); opacity: 1; }\\r\\n 100% { transform: perspective(400px) rotateY(90deg); opacity: 0; }\\r\\n}\\r\\n\\r\\n@keyframes rollIn {\\r\\n 0% { transform: translateX(-100%) rotate(-120deg); opacity: 0; }\\r\\n 100% { transform: translateX(0%) rotate(0deg); opacity: 1; }\\r\\n}\\r\\n\\r\\n@keyframes rollOut {\\r\\n 0% { transform: translateX(0%) rotate(0deg); opacity: 1; }\\r\\n 100% { transform: translateX(100%) rotate(120deg); opacity: 0; }\\r\\n}\\r\\n\\r\\n@keyframes rotateIn {\\r\\n 0% { transform: rotate(-90deg); opacity: 0; }\\r\\n 100% { transform: rotate(0); opacity: 1; }\\r\\n}\\r\\n\\r\\n@keyframes rotateOut {\\r\\n 0% { transform: rotate(0); opacity: 1; }\\r\\n 100% { transform: rotate(90deg); opacity: 0; }\\r\\n}\\r\\n\\r\\n@keyframes slideInUp {\\r\\n 0% { transform: translateY(100%); opacity: 0; }\\r\\n 100% { transform: translateY(0); opacity: 1; }\\r\\n}\\r\\n\\r\\n@keyframes slideInDown {\\r\\n 0% { transform: translateY(-100%); opacity: 0; }\\r\\n 100% { transform: translateY(0); opacity: 1; }\\r\\n}\\r\\n\\r\\n@keyframes slideInLeft {\\r\\n 0% { transform: translateX(-100%); opacity: 0; }\\r\\n 100% { transform: translateX(0); opacity: 1; }\\r\\n}\\r\\n\\r\\n@keyframes slideInRight {\\r\\n 0% { transform: translateX(100%); opacity: 0; }\\r\\n 100% { transform: translateX(0); opacity: 1; }\\r\\n}\\r\\n\\r\\n@keyframes slideOutUp {\\r\\n 0% { transform: translateY(0); opacity: 1; }\\r\\n 100% { transform: translateY(-100%); opacity: 0; }\\r\\n}\\r\\n\\r\\n@keyframes slideOutDown {\\r\\n 0% { transform: translateY(0); opacity: 1; }\\r\\n 100% { transform: translateY(100%); opacity: 0; }\\r\\n}\\r\\n\\r\\n@keyframes slideOutLeft {\\r\\n 0% { transform: translateX(0); opacity: 1; }\\r\\n 100% { transform: translateX(-100%); opacity: 0; }\\r\\n}\\r\\n\\r\\n@keyframes slideOutRight {\\r\\n 0% { transform: translateX(0); opacity: 1; }\\r\\n 100% { transform: translateX(100%); opacity: 0; }\\r\\n}\", \"\",{\"version\":3,\"sources\":[\"webpack://./material/src/surfaces/AnimationBox/AnimationBox.css\"],\"names\":[],\"mappings\":\"AAAA;EACE,gBAAgB;EAChB,WAAW;EACX,YAAY;EACZ,kBAAkB;AACpB;;AAEA;EACE,+BAA+B;AACjC;;AAEA;EACE,gCAAgC;AAClC;;AAEA;EACE,6BAA6B;AAC/B;;AAEA;EACE,gCAAgC;AAClC;;AAEA;EACE,iCAAiC;AACnC;;AAEA;EACE,+BAA+B;AACjC;;AAEA;EACE,sCAAsC;AACxC;;AAEA;EACE,uCAAuC;AACzC;;AAEA;EACE,mCAAmC;AACrC;;AAEA;EACE,oCAAoC;AACtC;;AAEA;EACE,sCAAsC;AACxC;;AAEA;EACE,wCAAwC;AAC1C;;AAEA;EACE,+BAA+B;AACjC;;AAEA;EACE,8BAA8B;AAChC;;AAEA;EACE,8BAA8B;AAChC;;AAEA;EACE,6BAA6B;AAC/B;;AAEA;EACE,8BAA8B;AAChC;;AAEA;EACE,iCAAiC;AACnC;;AAEA;EACE,4BAA4B;AAC9B;;AAEA;EACE,4BAA4B;AAC9B;;AAEA;EACE,6BAA6B;AAC/B;;AAEA;EACE,4BAA4B;AAC9B;;AAEA;EACE,6BAA6B;AAC/B;;AAEA;EACE,gCAAgC;AAClC;;AAEA;EACE,iCAAiC;AACnC;;AAEA;EACE,gCAAgC;AAClC;;AAEA;EACE,iCAAiC;AACnC;;AAEA;EACE,+BAA+B;AACjC;;AAEA;EACE,gCAAgC;AAClC;;AAEA;EACE,iCAAiC;AACnC;;AAEA;EACE,kCAAkC;AACpC;;AAEA;EACE,kCAAkC;AACpC;;AAEA;EACE,oCAAoC;AACtC;;AAEA;EACE,oCAAoC;AACtC;;AAEA;EACE,qCAAqC;AACvC;;AAEA;EACE,mCAAmC;AACrC;;AAEA;EACE,qCAAqC;AACvC;;AAEA;EACE,qCAAqC;AACvC;;AAEA;EACE,sCAAsC;AACxC;;;AAGA;EACE,KAAK,UAAU,EAAE;EACjB,OAAO,UAAU,EAAE;AACrB;;AAEA;EACE,KAAK,UAAU,EAAE;EACjB,OAAO,UAAU,EAAE;AACrB;;AAEA;EACE,KAAK,mBAAmB,EAAE;EAC1B,OAAO,mBAAmB,EAAE;AAC9B;;AAEA;EACE,KAAK,4BAA4B,EAAE;EACnC,OAAO,wBAAwB,EAAE;AACnC;;AAEA;EACE,KAAK,wBAAwB,EAAE;EAC/B,OAAO,2BAA2B,EAAE;AACtC;;AAEA;EACE,KAAK,uBAAuB,EAAE;EAC9B,OAAO,yBAAyB,EAAE;AACpC;;AAEA;EACE;MACI,yCAAyC;EAC7C;EACA;MACI,uCAAuC;EAC3C;AACF;;AAEA;EACE;MACI,qCAAqC;EACzC;EACA;MACI,0CAA0C;EAC9C;AACF;;AAEA;EACE;MACI,UAAU;MACV,mBAAmB;EACvB;EACA;MACI,UAAU;MACV,mBAAmB;EACvB;AACF;;;AAGA;EACE;MACI,UAAU;MACV,mBAAmB;EACvB;EACA;MACI,UAAU;EACd;EACA;MACI,UAAU;MACV,mBAAmB;EACvB;AACF;;AAEA;EACE;MACI,UAAU;MACV,4BAA4B;EAChC;EACA;MACI,UAAU;EACd;EACA;MACI,UAAU;MACV,wBAAwB;EAC5B;AACF;;AAEA;EACE;MACI,UAAU;MACV,wBAAwB;EAC5B;EACA;MACI,UAAU;EACd;EACA;MACI,UAAU;MACV,2BAA2B;EAC/B;AACF;;AAEA;EACE;IACE,wBAAwB;EAC1B;EACA;IACE,4BAA4B;EAC9B;EACA;IACE,4BAA4B;EAC9B;AACF;;AAEA;EACE;IACE,sBAAsB;EACxB;AACF;;AAEA;EACE;IACE,2BAA2B;EAC7B;EACA;IACE,0BAA0B;EAC5B;EACA;IACE,0BAA0B;EAC5B;EACA;IACE,yBAAyB;EAC3B;AACF;;AAEA;EACE;IACE,mCAAmC;EACrC;EACA;IACE,kCAAkC;EACpC;EACA;IACE,mCAAmC;EACrC;AACF;;AAEA;EACE;IACE,YAAY;EACd;AACF;;AAEA;EACE;IACE,oCAAoC;EACtC;EACA;IACE,oCAAoC;EACtC;EACA;IACE,oCAAoC;EACtC;EACA;IACE,oCAAoC;EACtC;EACA;IACE,oCAAoC;EACtC;AACF;;AAEA;EACE;IACE,wBAAwB;EAC1B;EACA;IACE,yBAAyB;EAC3B;EACA;IACE,uBAAuB;EACzB;EACA;IACE,wBAAwB;EAC1B;AACF;;AAEA;EACE;IACE,eAAe;EACjB;EACA;IACE,0CAA0C;EAC5C;EACA;IACE,wCAAwC;EAC1C;EACA;IACE,4CAA4C;EAC9C;EACA;IACE,4CAA4C;EAC9C;EACA;IACE,gDAAgD;EAClD;EACA;IACE,gDAAgD;EAClD;EACA;IACE,oDAAoD;EACtD;AACF;;AAEA;EACE,KAAK,yBAAyB,EAAE;EAChC,MAAM,yCAAyC,EAAE;EACjD,MAAM,uCAAuC,EAAE;EAC/C,MAAM,yCAAyC,EAAE;EACjD,MAAM,uCAAuC,EAAE;EAC/C,MAAM,wCAAwC,EAAE;EAChD,OAAO,yBAAyB,EAAE;AACpC;;AAEA;EACE,KAAK,oBAAoB,EAAE;EAC3B,MAAM,wBAAwB,EAAE,0BAA0B,EAAE;EAC5D,MAAM,8BAA8B,EAAE,UAAU,EAAE;EAClD,OAAO,8BAA8B,EAAE,UAAU,EAAE;AACrD;;AAEA;EACE,KAAK,wCAAwC,EAAE;EAC/C,OAAO,4CAA4C,EAAE;AACvD;;AAEA;EACE,KAAK,4CAA4C,EAAE,UAAU,EAAE;EAC/D,OAAO,2CAA2C,EAAE,UAAU,EAAE;AAClE;;AAEA;EACE,KAAK,2CAA2C,EAAE,UAAU,EAAE;EAC9D,OAAO,4CAA4C,EAAE,UAAU,EAAE;AACnE;;AAEA;EACE,KAAK,4CAA4C,EAAE,UAAU,EAAE;EAC/D,OAAO,2CAA2C,EAAE,UAAU,EAAE;AAClE;;AAEA;EACE,KAAK,2CAA2C,EAAE,UAAU,EAAE;EAC9D,OAAO,4CAA4C,EAAE,UAAU,EAAE;AACnE;;AAEA;EACE,KAAK,4CAA4C,EAAE,UAAU,EAAE;EAC/D,OAAO,sCAAsC,EAAE,UAAU,EAAE;AAC7D;;AAEA;EACE,KAAK,sCAAsC,EAAE,UAAU,EAAE;EACzD,OAAO,0CAA0C,EAAE,UAAU,EAAE;AACjE;;AAEA;EACE,KAAK,yBAAyB,EAAE,UAAU,EAAE;EAC5C,OAAO,oBAAoB,EAAE,UAAU,EAAE;AAC3C;;AAEA;EACE,KAAK,oBAAoB,EAAE,UAAU,EAAE;EACvC,OAAO,wBAAwB,EAAE,UAAU,EAAE;AAC/C;;AAEA;EACE,KAAK,2BAA2B,EAAE,UAAU,EAAE;EAC9C,OAAO,wBAAwB,EAAE,UAAU,EAAE;AAC/C;;AAEA;EACE,KAAK,4BAA4B,EAAE,UAAU,EAAE;EAC/C,OAAO,wBAAwB,EAAE,UAAU,EAAE;AAC/C;;AAEA;EACE,KAAK,4BAA4B,EAAE,UAAU,EAAE;EAC/C,OAAO,wBAAwB,EAAE,UAAU,EAAE;AAC/C;;AAEA;EACE,KAAK,2BAA2B,EAAE,UAAU,EAAE;EAC9C,OAAO,wBAAwB,EAAE,UAAU,EAAE;AAC/C;;AAEA;EACE,KAAK,wBAAwB,EAAE,UAAU,EAAE;EAC3C,OAAO,4BAA4B,EAAE,UAAU,EAAE;AACnD;;AAEA;EACE,KAAK,wBAAwB,EAAE,UAAU,EAAE;EAC3C,OAAO,2BAA2B,EAAE,UAAU,EAAE;AAClD;;AAEA;EACE,KAAK,wBAAwB,EAAE,UAAU,EAAE;EAC3C,OAAO,4BAA4B,EAAE,UAAU,EAAE;AACnD;;AAEA;EACE,KAAK,wBAAwB,EAAE,UAAU,EAAE;EAC3C,OAAO,2BAA2B,EAAE,UAAU,EAAE;AAClD\",\"sourcesContent\":[\".overflowContainer {\\r\\n overflow: hidden;\\r\\n width: 100%; \\r\\n height: 100%; \\r\\n position: relative;\\r\\n}\\r\\n\\r\\n.animation-fadeIn {\\r\\n animation: fadeIn 0.3s forwards;\\r\\n}\\r\\n\\r\\n.animation-fadeOut {\\r\\n animation: fadeOut 0.3s forwards;\\r\\n}\\r\\n\\r\\n.animation-grow {\\r\\n animation: grow 0.3s forwards;\\r\\n}\\r\\n\\r\\n.animation-slideIn {\\r\\n animation: slideIn 0.3s forwards;\\r\\n}\\r\\n\\r\\n.animation-slideOut {\\r\\n animation: slideOut 0.3s forwards;\\r\\n}\\r\\n\\r\\n.animation-rotate {\\r\\n animation: rotate 0.6s forwards;\\r\\n}\\r\\n\\r\\n.animation-slideInRotate {\\r\\n animation: slideInRotate 0.6s forwards;\\r\\n}\\r\\n\\r\\n.animation-slideOutRotate {\\r\\n animation: slideOutRotate 0.6s forwards;\\r\\n}\\r\\n\\r\\n.animation-fadeInGrow {\\r\\n animation: fadeInGrow 0.6s forwards;\\r\\n}\\r\\n\\r\\n.animation-fadeOutGrow {\\r\\n animation: fadeOutGrow 0.6s forwards;\\r\\n}\\r\\n\\r\\n.animation-fadeInSlideIn {\\r\\n animation: fadeInSlideIn 0.6s forwards;\\r\\n}\\r\\n\\r\\n.animation-fadeOutSlideOut {\\r\\n animation: fadeOutSlideOut 0.6s forwards;\\r\\n}\\r\\n\\r\\n.animation-bounce {\\r\\n animation: bounce 0.5s forwards;\\r\\n}\\r\\n\\r\\n.animation-pulse {\\r\\n animation: pulse 0.5s forwards;\\r\\n}\\r\\n\\r\\n.animation-shake {\\r\\n animation: shake 0.5s forwards;\\r\\n}\\r\\n\\r\\n.animation-tada {\\r\\n animation: tada 0.5s forwards;\\r\\n}\\r\\n\\r\\n.animation-flash {\\r\\n animation: flash 0.5s forwards;\\r\\n}\\r\\n\\r\\n.animation-rubberBand {\\r\\n animation: rubberBand 1s forwards;\\r\\n}\\r\\n\\r\\n.animation-swing {\\r\\n animation: swing 1s forwards;\\r\\n}\\r\\n\\r\\n.animation-jello {\\r\\n animation: jello 1s forwards;\\r\\n}\\r\\n\\r\\n.animation-wobble {\\r\\n animation: wobble 1s forwards;\\r\\n}\\r\\n\\r\\n.animation-hinge {\\r\\n animation: hinge 2s forwards;\\r\\n}\\r\\n\\r\\n.animation-flip {\\r\\n animation: flip 0.6s forwards;\\r\\n}\\r\\n\\r\\n.animation-flipInX {\\r\\n animation: flipInX 0.6s forwards;\\r\\n}\\r\\n\\r\\n.animation-flipOutX {\\r\\n animation: flipOutX 0.6s forwards;\\r\\n}\\r\\n\\r\\n.animation-flipInY {\\r\\n animation: flipInY 0.6s forwards;\\r\\n}\\r\\n\\r\\n.animation-flipOutY {\\r\\n animation: flipOutY 0.6s forwards;\\r\\n}\\r\\n\\r\\n.animation-rollIn {\\r\\n animation: rollIn 0.6s forwards;\\r\\n}\\r\\n\\r\\n.animation-rollOut {\\r\\n animation: rollOut 0.6s forwards;\\r\\n}\\r\\n\\r\\n.animation-rotateIn {\\r\\n animation: rotateIn 0.6s forwards;\\r\\n}\\r\\n\\r\\n.animation-rotateOut {\\r\\n animation: rotateOut 0.6s forwards;\\r\\n}\\r\\n\\r\\n.animation-slideInUp {\\r\\n animation: slideInUp 0.6s forwards;\\r\\n}\\r\\n\\r\\n.animation-slideInDown {\\r\\n animation: slideInDown 0.6s forwards;\\r\\n}\\r\\n\\r\\n.animation-slideInLeft {\\r\\n animation: slideInLeft 0.6s forwards;\\r\\n}\\r\\n\\r\\n.animation-slideInRight {\\r\\n animation: slideInRight 0.6s forwards;\\r\\n}\\r\\n\\r\\n.animation-slideOutUp {\\r\\n animation: slideOutUp 0.6s forwards;\\r\\n}\\r\\n\\r\\n.animation-slideOutDown {\\r\\n animation: slideOutDown 0.6s forwards;\\r\\n}\\r\\n\\r\\n.animation-slideOutLeft {\\r\\n animation: slideOutLeft 0.6s forwards;\\r\\n}\\r\\n\\r\\n.animation-slideOutRight {\\r\\n animation: slideOutRight 0.6s forwards;\\r\\n}\\r\\n\\r\\n\\r\\n@keyframes fadeIn {\\r\\n 0% { opacity: 0; }\\r\\n 100% { opacity: 1; }\\r\\n}\\r\\n\\r\\n@keyframes fadeOut {\\r\\n 0% { opacity: 1; }\\r\\n 100% { opacity: 0; }\\r\\n}\\r\\n\\r\\n@keyframes grow {\\r\\n 0% { transform: scale(0); }\\r\\n 100% { transform: scale(1); }\\r\\n}\\r\\n\\r\\n@keyframes slideIn {\\r\\n 0% { transform: translateX(-100%); }\\r\\n 100% { transform: translateX(0); }\\r\\n}\\r\\n\\r\\n@keyframes slideOut {\\r\\n 0% { transform: translateX(0); }\\r\\n 100% { transform: translateX(100%); }\\r\\n}\\r\\n\\r\\n@keyframes rotate {\\r\\n 0% { transform: rotate(0deg); }\\r\\n 100% { transform: rotate(360deg); }\\r\\n}\\r\\n\\r\\n@keyframes slideInRotate {\\r\\n 0% {\\r\\n transform: translateX(-100%) rotate(0deg);\\r\\n }\\r\\n 100% {\\r\\n transform: translateX(0) rotate(360deg);\\r\\n }\\r\\n}\\r\\n\\r\\n@keyframes slideOutRotate {\\r\\n 0% {\\r\\n transform: translateX(0) rotate(0deg);\\r\\n }\\r\\n 100% {\\r\\n transform: translateX(100%) rotate(360deg);\\r\\n }\\r\\n}\\r\\n\\r\\n@keyframes fadeInGrow {\\r\\n 0% {\\r\\n opacity: 0;\\r\\n transform: scale(0);\\r\\n }\\r\\n 100% {\\r\\n opacity: 1;\\r\\n transform: scale(1);\\r\\n }\\r\\n}\\r\\n\\r\\n\\r\\n@keyframes fadeOutGrow {\\r\\n 0% {\\r\\n opacity: 1;\\r\\n transform: scale(1);\\r\\n }\\r\\n 50% {\\r\\n opacity: 0;\\r\\n }\\r\\n 100% {\\r\\n opacity: 0;\\r\\n transform: scale(0);\\r\\n }\\r\\n}\\r\\n\\r\\n@keyframes fadeInSlideIn {\\r\\n 0% {\\r\\n opacity: 0;\\r\\n transform: translateX(-100%);\\r\\n }\\r\\n 50% {\\r\\n opacity: 1;\\r\\n }\\r\\n 100% {\\r\\n opacity: 1;\\r\\n transform: translateX(0);\\r\\n }\\r\\n}\\r\\n\\r\\n@keyframes fadeOutSlideOut {\\r\\n 0% {\\r\\n opacity: 1;\\r\\n transform: translateX(0);\\r\\n }\\r\\n 50% {\\r\\n opacity: 0;\\r\\n }\\r\\n 100% {\\r\\n opacity: 0;\\r\\n transform: translateX(100%);\\r\\n }\\r\\n}\\r\\n\\r\\n@keyframes bounce {\\r\\n 0%, 20%, 50%, 80%, 100% {\\r\\n transform: translateY(0);\\r\\n }\\r\\n 40% {\\r\\n transform: translateY(-20px);\\r\\n }\\r\\n 60% {\\r\\n transform: translateY(-10px);\\r\\n }\\r\\n}\\r\\n\\r\\n@keyframes pulse {\\r\\n 50% {\\r\\n transform: scale(1.05);\\r\\n }\\r\\n}\\r\\n\\r\\n@keyframes shake {\\r\\n 10%, 90% {\\r\\n transform: translateX(-10%);\\r\\n }\\r\\n 20%, 80% {\\r\\n transform: translateX(10%);\\r\\n }\\r\\n 30%, 50%, 70% {\\r\\n transform: translateX(-5%);\\r\\n }\\r\\n 40%, 60% {\\r\\n transform: translateX(5%);\\r\\n }\\r\\n}\\r\\n\\r\\n@keyframes tada {\\r\\n 10%, 20% {\\r\\n transform: scale(0.9) rotate(-3deg);\\r\\n }\\r\\n 30%, 50%, 70%, 90% {\\r\\n transform: scale(1.1) rotate(3deg);\\r\\n }\\r\\n 40%, 60%, 80% {\\r\\n transform: scale(1.1) rotate(-3deg);\\r\\n }\\r\\n}\\r\\n\\r\\n@keyframes flash {\\r\\n 50% {\\r\\n opacity: 0.3;\\r\\n }\\r\\n}\\r\\n\\r\\n@keyframes rubberBand {\\r\\n 30% {\\r\\n transform: scaleX(1.25) scaleY(0.75);\\r\\n }\\r\\n 40% {\\r\\n transform: scaleX(0.75) scaleY(1.25);\\r\\n }\\r\\n 50% {\\r\\n transform: scaleX(1.15) scaleY(0.85);\\r\\n }\\r\\n 65% {\\r\\n transform: scaleX(0.95) scaleY(1.05);\\r\\n }\\r\\n 75% {\\r\\n transform: scaleX(1.05) scaleY(0.95);\\r\\n }\\r\\n}\\r\\n\\r\\n@keyframes swing {\\r\\n 20% {\\r\\n transform: rotate(15deg);\\r\\n }\\r\\n 40% {\\r\\n transform: rotate(-10deg);\\r\\n }\\r\\n 60% {\\r\\n transform: rotate(5deg);\\r\\n }\\r\\n 80% {\\r\\n transform: rotate(-5deg);\\r\\n }\\r\\n}\\r\\n\\r\\n@keyframes jello {\\r\\n 11%, 100% {\\r\\n transform: none;\\r\\n }\\r\\n 22% {\\r\\n transform: skewX(-12.5deg) skewY(-12.5deg);\\r\\n }\\r\\n 33% {\\r\\n transform: skewX(6.25deg) skewY(6.25deg);\\r\\n }\\r\\n 44% {\\r\\n transform: skewX(-3.125deg) skewY(-3.125deg);\\r\\n }\\r\\n 55% {\\r\\n transform: skewX(1.5625deg) skewY(1.5625deg);\\r\\n }\\r\\n 66% {\\r\\n transform: skewX(-0.78125deg) skewY(-0.78125deg);\\r\\n }\\r\\n 77% {\\r\\n transform: skewX(0.390625deg) skewY(0.390625deg);\\r\\n }\\r\\n 88% {\\r\\n transform: skewX(-0.1953125deg) skewY(-0.1953125deg);\\r\\n }\\r\\n}\\r\\n\\r\\n@keyframes wobble {\\r\\n 0% { transform: translateX(0%); }\\r\\n 15% { transform: translateX(-25%) rotate(-5deg); }\\r\\n 30% { transform: translateX(20%) rotate(3deg); }\\r\\n 45% { transform: translateX(-15%) rotate(-3deg); }\\r\\n 60% { transform: translateX(10%) rotate(2deg); } \\r\\n 75% { transform: translateX(-5%) rotate(-1deg); }\\r\\n 100% { transform: translateX(0%); }\\r\\n}\\r\\n\\r\\n@keyframes hinge {\\r\\n 0% { transform: rotate(0); }\\r\\n 20% { transform: rotate(80deg); transform-origin: top left; }\\r\\n 40% { transform: translate(0, 700px); opacity: 1; }\\r\\n 100% { transform: translate(0, 700px); opacity: 0; }\\r\\n}\\r\\n\\r\\n@keyframes flip {\\r\\n 0% { transform: perspective(400px) rotateY(0); }\\r\\n 100% { transform: perspective(400px) rotateY(1turn); }\\r\\n}\\r\\n\\r\\n@keyframes flipInX {\\r\\n 0% { transform: perspective(400px) rotateX(90deg); opacity: 0; }\\r\\n 100% { transform: perspective(400px) rotateX(0deg); opacity: 1; }\\r\\n}\\r\\n\\r\\n@keyframes flipOutX {\\r\\n 0% { transform: perspective(400px) rotateX(0deg); opacity: 1; }\\r\\n 100% { transform: perspective(400px) rotateX(90deg); opacity: 0; }\\r\\n}\\r\\n\\r\\n@keyframes flipInY {\\r\\n 0% { transform: perspective(400px) rotateY(90deg); opacity: 0; }\\r\\n 100% { transform: perspective(400px) rotateY(0deg); opacity: 1; }\\r\\n}\\r\\n\\r\\n@keyframes flipOutY {\\r\\n 0% { transform: perspective(400px) rotateY(0deg); opacity: 1; }\\r\\n 100% { transform: perspective(400px) rotateY(90deg); opacity: 0; }\\r\\n}\\r\\n\\r\\n@keyframes rollIn {\\r\\n 0% { transform: translateX(-100%) rotate(-120deg); opacity: 0; }\\r\\n 100% { transform: translateX(0%) rotate(0deg); opacity: 1; }\\r\\n}\\r\\n\\r\\n@keyframes rollOut {\\r\\n 0% { transform: translateX(0%) rotate(0deg); opacity: 1; }\\r\\n 100% { transform: translateX(100%) rotate(120deg); opacity: 0; }\\r\\n}\\r\\n\\r\\n@keyframes rotateIn {\\r\\n 0% { transform: rotate(-90deg); opacity: 0; }\\r\\n 100% { transform: rotate(0); opacity: 1; }\\r\\n}\\r\\n\\r\\n@keyframes rotateOut {\\r\\n 0% { transform: rotate(0); opacity: 1; }\\r\\n 100% { transform: rotate(90deg); opacity: 0; }\\r\\n}\\r\\n\\r\\n@keyframes slideInUp {\\r\\n 0% { transform: translateY(100%); opacity: 0; }\\r\\n 100% { transform: translateY(0); opacity: 1; }\\r\\n}\\r\\n\\r\\n@keyframes slideInDown {\\r\\n 0% { transform: translateY(-100%); opacity: 0; }\\r\\n 100% { transform: translateY(0); opacity: 1; }\\r\\n}\\r\\n\\r\\n@keyframes slideInLeft {\\r\\n 0% { transform: translateX(-100%); opacity: 0; }\\r\\n 100% { transform: translateX(0); opacity: 1; }\\r\\n}\\r\\n\\r\\n@keyframes slideInRight {\\r\\n 0% { transform: translateX(100%); opacity: 0; }\\r\\n 100% { transform: translateX(0); opacity: 1; }\\r\\n}\\r\\n\\r\\n@keyframes slideOutUp {\\r\\n 0% { transform: translateY(0); opacity: 1; }\\r\\n 100% { transform: translateY(-100%); opacity: 0; }\\r\\n}\\r\\n\\r\\n@keyframes slideOutDown {\\r\\n 0% { transform: translateY(0); opacity: 1; }\\r\\n 100% { transform: translateY(100%); opacity: 0; }\\r\\n}\\r\\n\\r\\n@keyframes slideOutLeft {\\r\\n 0% { transform: translateX(0); opacity: 1; }\\r\\n 100% { transform: translateX(-100%); opacity: 0; }\\r\\n}\\r\\n\\r\\n@keyframes slideOutRight {\\r\\n 0% { transform: translateX(0); opacity: 1; }\\r\\n 100% { transform: translateX(100%); opacity: 0; }\\r\\n}\"],\"sourceRoot\":\"\"}]);\n// Exports\nexport default ___CSS_LOADER_EXPORT___;\n","\"use strict\";\n\n/*\n MIT License http://www.opensource.org/licenses/mit-license.php\n Author Tobias Koppers @sokra\n*/\nmodule.exports = function (cssWithMappingToString) {\n var list = [];\n\n // return the list of modules as css string\n list.toString = function toString() {\n return this.map(function (item) {\n var content = \"\";\n var needLayer = typeof item[5] !== \"undefined\";\n if (item[4]) {\n content += \"@supports (\".concat(item[4], \") {\");\n }\n if (item[2]) {\n content += \"@media \".concat(item[2], \" {\");\n }\n if (needLayer) {\n content += \"@layer\".concat(item[5].length > 0 ? \" \".concat(item[5]) : \"\", \" {\");\n }\n content += cssWithMappingToString(item);\n if (needLayer) {\n content += \"}\";\n }\n if (item[2]) {\n content += \"}\";\n }\n if (item[4]) {\n content += \"}\";\n }\n return content;\n }).join(\"\");\n };\n\n // import a list of modules into the list\n list.i = function i(modules, media, dedupe, supports, layer) {\n if (typeof modules === \"string\") {\n modules = [[null, modules, undefined]];\n }\n var alreadyImportedModules = {};\n if (dedupe) {\n for (var k = 0; k < this.length; k++) {\n var id = this[k][0];\n if (id != null) {\n alreadyImportedModules[id] = true;\n }\n }\n }\n for (var _k = 0; _k < modules.length; _k++) {\n var item = [].concat(modules[_k]);\n if (dedupe && alreadyImportedModules[item[0]]) {\n continue;\n }\n if (typeof layer !== \"undefined\") {\n if (typeof item[5] === \"undefined\") {\n item[5] = layer;\n } else {\n item[1] = \"@layer\".concat(item[5].length > 0 ? \" \".concat(item[5]) : \"\", \" {\").concat(item[1], \"}\");\n item[5] = layer;\n }\n }\n if (media) {\n if (!item[2]) {\n item[2] = media;\n } else {\n item[1] = \"@media \".concat(item[2], \" {\").concat(item[1], \"}\");\n item[2] = media;\n }\n }\n if (supports) {\n if (!item[4]) {\n item[4] = \"\".concat(supports);\n } else {\n item[1] = \"@supports (\".concat(item[4], \") {\").concat(item[1], \"}\");\n item[4] = supports;\n }\n }\n list.push(item);\n }\n };\n return list;\n};","\"use strict\";\n\nmodule.exports = function (item) {\n var content = item[1];\n var cssMapping = item[3];\n if (!cssMapping) {\n return content;\n }\n if (typeof btoa === \"function\") {\n var base64 = btoa(unescape(encodeURIComponent(JSON.stringify(cssMapping))));\n var data = \"sourceMappingURL=data:application/json;charset=utf-8;base64,\".concat(base64);\n var sourceMapping = \"/*# \".concat(data, \" */\");\n return [content].concat([sourceMapping]).join(\"\\n\");\n }\n return [content].join(\"\\n\");\n};","\"use strict\";\n\nvar stylesInDOM = [];\nfunction getIndexByIdentifier(identifier) {\n var result = -1;\n for (var i = 0; i < stylesInDOM.length; i++) {\n if (stylesInDOM[i].identifier === identifier) {\n result = i;\n break;\n }\n }\n return result;\n}\nfunction modulesToDom(list, options) {\n var idCountMap = {};\n var identifiers = [];\n for (var i = 0; i < list.length; i++) {\n var item = list[i];\n var id = options.base ? item[0] + options.base : item[0];\n var count = idCountMap[id] || 0;\n var identifier = \"\".concat(id, \" \").concat(count);\n idCountMap[id] = count + 1;\n var indexByIdentifier = getIndexByIdentifier(identifier);\n var obj = {\n css: item[1],\n media: item[2],\n sourceMap: item[3],\n supports: item[4],\n layer: item[5]\n };\n if (indexByIdentifier !== -1) {\n stylesInDOM[indexByIdentifier].references++;\n stylesInDOM[indexByIdentifier].updater(obj);\n } else {\n var updater = addElementStyle(obj, options);\n options.byIndex = i;\n stylesInDOM.splice(i, 0, {\n identifier: identifier,\n updater: updater,\n references: 1\n });\n }\n identifiers.push(identifier);\n }\n return identifiers;\n}\nfunction addElementStyle(obj, options) {\n var api = options.domAPI(options);\n api.update(obj);\n var updater = function updater(newObj) {\n if (newObj) {\n if (newObj.css === obj.css && newObj.media === obj.media && newObj.sourceMap === obj.sourceMap && newObj.supports === obj.supports && newObj.layer === obj.layer) {\n return;\n }\n api.update(obj = newObj);\n } else {\n api.remove();\n }\n };\n return updater;\n}\nmodule.exports = function (list, options) {\n options = options || {};\n list = list || [];\n var lastIdentifiers = modulesToDom(list, options);\n return function update(newList) {\n newList = newList || [];\n for (var i = 0; i < lastIdentifiers.length; i++) {\n var identifier = lastIdentifiers[i];\n var index = getIndexByIdentifier(identifier);\n stylesInDOM[index].references--;\n }\n var newLastIdentifiers = modulesToDom(newList, options);\n for (var _i = 0; _i < lastIdentifiers.length; _i++) {\n var _identifier = lastIdentifiers[_i];\n var _index = getIndexByIdentifier(_identifier);\n if (stylesInDOM[_index].references === 0) {\n stylesInDOM[_index].updater();\n stylesInDOM.splice(_index, 1);\n }\n }\n lastIdentifiers = newLastIdentifiers;\n };\n};","\"use strict\";\n\nvar memo = {};\n\n/* istanbul ignore next */\nfunction getTarget(target) {\n if (typeof memo[target] === \"undefined\") {\n var styleTarget = document.querySelector(target);\n\n // Special case to return head of iframe instead of iframe itself\n if (window.HTMLIFrameElement && styleTarget instanceof window.HTMLIFrameElement) {\n try {\n // This will throw an exception if access to iframe is blocked\n // due to cross-origin restrictions\n styleTarget = styleTarget.contentDocument.head;\n } catch (e) {\n // istanbul ignore next\n styleTarget = null;\n }\n }\n memo[target] = styleTarget;\n }\n return memo[target];\n}\n\n/* istanbul ignore next */\nfunction insertBySelector(insert, style) {\n var target = getTarget(insert);\n if (!target) {\n throw new Error(\"Couldn't find a style target. This probably means that the value for the 'insert' parameter is invalid.\");\n }\n target.appendChild(style);\n}\nmodule.exports = insertBySelector;","\"use strict\";\n\n/* istanbul ignore next */\nfunction insertStyleElement(options) {\n var element = document.createElement(\"style\");\n options.setAttributes(element, options.attributes);\n options.insert(element, options.options);\n return element;\n}\nmodule.exports = insertStyleElement;","\"use strict\";\n\n/* istanbul ignore next */\nfunction setAttributesWithoutAttributes(styleElement) {\n var nonce = typeof __webpack_nonce__ !== \"undefined\" ? __webpack_nonce__ : null;\n if (nonce) {\n styleElement.setAttribute(\"nonce\", nonce);\n }\n}\nmodule.exports = setAttributesWithoutAttributes;","\"use strict\";\n\n/* istanbul ignore next */\nfunction apply(styleElement, options, obj) {\n var css = \"\";\n if (obj.supports) {\n css += \"@supports (\".concat(obj.supports, \") {\");\n }\n if (obj.media) {\n css += \"@media \".concat(obj.media, \" {\");\n }\n var needLayer = typeof obj.layer !== \"undefined\";\n if (needLayer) {\n css += \"@layer\".concat(obj.layer.length > 0 ? \" \".concat(obj.layer) : \"\", \" {\");\n }\n css += obj.css;\n if (needLayer) {\n css += \"}\";\n }\n if (obj.media) {\n css += \"}\";\n }\n if (obj.supports) {\n css += \"}\";\n }\n var sourceMap = obj.sourceMap;\n if (sourceMap && typeof btoa !== \"undefined\") {\n css += \"\\n/*# sourceMappingURL=data:application/json;base64,\".concat(btoa(unescape(encodeURIComponent(JSON.stringify(sourceMap)))), \" */\");\n }\n\n // For old IE\n /* istanbul ignore if */\n options.styleTagTransform(css, styleElement, options.options);\n}\nfunction removeStyleElement(styleElement) {\n // istanbul ignore if\n if (styleElement.parentNode === null) {\n return false;\n }\n styleElement.parentNode.removeChild(styleElement);\n}\n\n/* istanbul ignore next */\nfunction domAPI(options) {\n if (typeof document === \"undefined\") {\n return {\n update: function update() {},\n remove: function remove() {}\n };\n }\n var styleElement = options.insertStyleElement(options);\n return {\n update: function update(obj) {\n apply(styleElement, options, obj);\n },\n remove: function remove() {\n removeStyleElement(styleElement);\n }\n };\n}\nmodule.exports = domAPI;","\"use strict\";\n\n/* istanbul ignore next */\nfunction styleTagTransform(css, styleElement) {\n if (styleElement.styleSheet) {\n styleElement.styleSheet.cssText = css;\n } else {\n while (styleElement.firstChild) {\n styleElement.removeChild(styleElement.firstChild);\n }\n styleElement.appendChild(document.createTextNode(css));\n }\n}\nmodule.exports = styleTagTransform;","__webpack_require__.nc = undefined;","import React from \"react\";\r\nimport { pkgConfigMaterial } from \"../../../\";\r\nexport default class ErrorBoundary extends React.Component {\r\n constructor(props) {\r\n super(props);\r\n this.state = { error: false };\r\n }\r\n\r\n static getDerivedStateFromError(error) {\r\n // Changing the state to true if some error occurs\r\n if (pkgConfigMaterial?.blnIsTestingMode) {\r\n return {\r\n error: true,\r\n };\r\n }\r\n }\r\n\r\n render() {\r\n if (this.state.error && pkgConfigMaterial?.blnIsTestingMode) {\r\n return (\r\n \r\n Oops! Something is wrong.\r\n
\r\n );\r\n }\r\n return this?.props?.children;\r\n }\r\n}\r\n","import React, { forwardRef, useContext } from \"react\";\r\nimport { ContextThemeProvider, styleFunction } from \"@cbmisorg/styles\";\r\nimport AvatarStyle from \"./AvatarStyle\";\r\nimport ErrorBoundary from \"../../_helper/errorHandeling/ErrorBoundary/ErrorBoundary\";\r\n\r\nconst Avatar = forwardRef((/**@type {any}*/props, ref) => {\r\n const { src, alt, color, mode, sx, hidden, disabled, dir, className, ...rest } = props;\r\n const theTheme = useContext(ContextThemeProvider);\r\n const {classesName, style, styleSx} = AvatarStyle(theTheme);\r\n const classes = style();\r\n const classesSx = styleSx({ sx: props?.sx, src, color });\r\n\r\n const itemClasses = styleFunction.getClassName(classes?.[classesName?.avatar], classesSx?.[classesName?.sx], styleFunction.CheckDirectionItem(dir),styleFunction.CheckDisabledItem(disabled), styleFunction.CheckHiddenItem(hidden),styleFunction.checkExistsMargin(rest),styleFunction.checkExistsPadding(rest), className);\r\n\r\n return (\r\n \r\n
\r\n {props.children} \r\n
\r\n
\r\n );\r\n});\r\n\r\nexport default Avatar;\r\n","import {\r\n StyleBuilder,\r\n styleVariables,\r\n cssKeys,\r\n mainTheme,\r\n styleFunction,\r\n} from \"@cbmisorg/styles\";\r\n\r\nexport default(objThemeInfo)=>{\r\n const cssObject = objThemeInfo?.cssObject || mainTheme?.cssObject;\r\n\r\n const classesName = {\r\n avatar: `${styleVariables?.prefixDefaultClassName}_avatar`,\r\n avatar_contain: `${styleVariables?.prefixDefaultClassName}_avatar_contain`,\r\n shape_circle: `${styleVariables?.prefixDefaultClassName}_shape_circle`,\r\n sx:`${styleVariables?.prefixDefaultClassName}_avatar_sx`\r\n }\r\n\r\n const style = StyleBuilder({\r\n blnRandomPrefix: false,\r\n blnIsDefaultStyle: true,\r\n blnCbmisStyle: true,\r\n objStyles: {\r\n [classesName?.avatar]: {\r\n display: cssObject?.display?.[cssKeys?.block],\r\n position: cssObject.position?.[cssKeys?.relative],\r\n margin: cssObject.spacing?.[cssKeys?.auto],\r\n padding: cssObject.spacing?.[cssKeys?.auto],\r\n },\r\n [classesName?.avatar_contain]: {\r\n display: cssObject?.display?.flex,\r\n width: cssObject?.size?.full,\r\n height: cssObject?.size?.full,\r\n justifyContent: \"center\",\r\n alignItems: \"center\",\r\n textAlign: \"center\",\r\n verticalAlign: \"middle\",\r\n margin: cssObject.spacing?.auto,\r\n padding: cssObject.spacing?.auto,\r\n position: cssObject.position?.absolute,\r\n top: \"0\",\r\n left: \"0\",\r\n zIndex: \"var(--cbmis-z-index-1)\",\r\n color: cssObject?.color?.currentColor,\r\n },\r\n },\r\n });\r\n\r\n const styleSx = StyleBuilder({\r\n blnRandomPrefix: true,\r\n blnIsDefaultStyle: false,\r\n blnCbmisStyle: true,\r\n objStyles: {\r\n [classesName.sx]: (props) => {\r\n const obj ={\r\n color: cssObject?.color?.[cssKeys?.bodyColorBgDark],\r\n width: cssObject.size?.[cssKeys?.item_lg],\r\n height: cssObject.size?.[cssKeys?.item_lg],\r\n fontSize: cssObject?.text?.size?.[cssKeys?.subtitle2],\r\n backgroundColor: styleFunction.checkColorReturnValue(props?.color || cssObject?.color?.[cssKeys?.bodyColorBgDark]),\r\n ...props?.sx\r\n }\r\n if(props?.src){\r\n obj.backgroundImage= `url(${props?.src})`\r\n obj.backgroundPosition= \"center\"\r\n obj.backgroundSize= \"100% 100%\"\r\n obj.backgroundRepeat= \"no-repeat\"\r\n }\r\n return {\r\n ...getAvatarMode(props?.mode),\r\n ...obj\r\n };\r\n },\r\n },\r\n });\r\n\r\n\r\n const getAvatarMode = (mode) => {\r\n switch (String(mode)?.toLowerCase()) {\r\n default:\r\n return {\r\n\r\n borderRadius: cssObject?.border?.[cssKeys?.rounded]?.pill,\r\n WebkitBorderRadius: cssObject?.border?.[cssKeys?.rounded]?.pill,\r\n MozBorderRadius: cssObject?.border?.[cssKeys?.rounded]?.pill,\r\n };\r\n }\r\n };\r\n\r\n return{\r\n classesName,\r\n style,\r\n styleSx,\r\n }\r\n}","import React, { forwardRef, useContext, useId } from \"react\";\r\nimport { ContextThemeProvider, styleFunction } from \"@cbmisorg/styles\";\r\nimport BadgeStyle from \"./BadgeStyle\";\r\nimport ErrorBoundary from \"../../_helper/errorHandeling/ErrorBoundary/ErrorBoundary\";\r\n\r\nconst Badge = forwardRef((/**@type {any}*/props, ref) => {\r\n const { content, mode, vertical, horizontal, color, sx, hidden, id, disabled, dir, className, ...rest } = props;\r\n const theTheme = useContext(ContextThemeProvider);\r\n const {classesName, style, styleSx} = BadgeStyle(theTheme);\r\n const classes = style();\r\n const classesSx = styleSx({...props?.sx, mode, vertical, horizontal, color});\r\n const comID = id || String(useId()).slice(1,-1)\r\n\r\n const classesNamesTag0 = styleFunction?.getClassName(classes?.[classesName?.badge_container], styleFunction.CheckDirectionItem(dir));\r\n const classesNamesTag1 = styleFunction?.getClassName(classes?.[classesName?.badge], classes?.[classesName?.mdl_badge], classesSx?.[classesName?.mdl_badge]);\r\n const classesNamesTag2 = styleFunction?.getClassName(classes?.[classesName?.badge_content], classesSx?.[classesName?.badge_content], classesSx?.[classesName?.sx], styleFunction.CheckDisabledItem(disabled), styleFunction.CheckHiddenItem(hidden), styleFunction.checkExistsMargin(rest), styleFunction.checkExistsPadding(rest), className || \"\");\r\n\r\n return (\r\n \r\n
\r\n
{props?.children} \r\n
\r\n {content}\r\n
\r\n
\r\n
\r\n );\r\n});\r\n\r\nexport default Badge;\r\n","import {\r\n StyleBuilder,\r\n styleVariables,\r\n cssKeys,\r\n mainTheme,\r\n styleFunction,\r\n} from \"@cbmisorg/styles\";\r\n\r\nexport default(objThemeInfo)=>{\r\n const cssObject = objThemeInfo?.cssObject || mainTheme?.cssObject;\r\n const currentBaseSize = objThemeInfo?.currentBaseSize || mainTheme?.currentBaseSize;\r\n\r\n const classesName = {\r\n badge_container: `${styleVariables?.prefixDefaultClassName}_badge_container`,\r\n badge: `${styleVariables?.prefixDefaultClassName}_badge`,\r\n mdl_badge: `${styleVariables?.prefixDefaultClassName}_mdl_badge`,\r\n badge_content:`${styleVariables?.prefixDefaultClassName}_badge_content`,\r\n sx:`${styleVariables?.prefixDefaultClassName}_badge_sx`,\r\n }\r\n\r\n const style = StyleBuilder({\r\n blnRandomPrefix: false,\r\n blnIsDefaultStyle: true,\r\n blnCbmisStyle: true,\r\n objStyles: {\r\n [classesName?.badge_container]: {\r\n position: cssObject.position?.[cssKeys?.relative],\r\n boxSizing: \"inherit\",\r\n display: \"inline-flex\",\r\n verticalAlign: \"middle\",\r\n flexShrink: 0,\r\n margin: 0,\r\n flexDirection: \"column\",\r\n alignItems: \"center\",\r\n },\r\n [classesName?.badge]: {\r\n lineHeight: 1,\r\n display: \"block\",\r\n margin: 0,\r\n },\r\n [classesName?.mdl_badge]: {\r\n display: \"block\",\r\n margin: 0,\r\n position:\"relative\",\r\n },\r\n [classesName?.badge_content]: {\r\n position: \"absolute\",\r\n zIndex: 1,\r\n display: \"flex\",\r\n justifyContent:\"center\",\r\n textAlign:\"center\",\r\n flexFlow: \"row wrap\",\r\n boxPack: \"center\",\r\n WebkitBoxPack: \"center\",\r\n placeContent: \"center\",\r\n boxAlign: \"center\",\r\n WebkitBoxAlign: \"center\",\r\n alignItems: \"center\",\r\n boxSizing: \"border-box\",\r\n fontWeight: cssObject?.fontWeight?.[cssKeys?.fontWeight_md],\r\n lineHeight: 10,\r\n padding: \"auto\",\r\n transition: \"transform 225ms cubic-bezier(0.4, 0, 0.2, 1) 0ms\",\r\n },\r\n },\r\n });\r\n\r\n const styleSx = StyleBuilder({\r\n blnRandomPrefix: true,\r\n blnIsDefaultStyle: false,\r\n blnCbmisStyle: true,\r\n objStyles: {\r\n [classesName?.mdl_badge]: {\r\n fontSize: cssObject?.size?.[cssKeys?.body1]\r\n },\r\n [classesName?.badge_content]:(props)=>{\r\n return {\r\n fontWeight: cssObject?.fontWeight?.[cssKeys?.fontWeight_md],\r\n color:cssObject?.color?.[cssKeys?.light],\r\n border: `${currentBaseSize/5}rem solid ${cssObject?.color?.[cssKeys?.white]}`,\r\n fontSize: `${currentBaseSize*2.7}rem`,\r\n minWidth: `${currentBaseSize*4}rem`,\r\n height: `${currentBaseSize*4}rem`,\r\n borderRadius: cssObject?.border?.[cssKeys?.rounded]?.pill,\r\n backgroundColor: styleFunction.checkColorReturnValue(props?.color || cssObject?.color?.[cssKeys?.primary]),\r\n ...getVertical(props?.vertical),\r\n ...getHorizontal(props?.horizontal),\r\n ...getStyleMode(props?.mode),\r\n }\r\n },\r\n [classesName?.sx]: (props) => {\r\n return {\r\n ...props?.sx,\r\n };\r\n },\r\n },\r\n });\r\n\r\n const getHorizontal = (horizontal) => {\r\n const getHorizontal = String(horizontal).toLowerCase();\r\n switch (getHorizontal) {\r\n case \"left\":\r\n return {\r\n position: \"absolute\",\r\n left: `-${cssObject.spacing?.[cssKeys?.xs]}`,\r\n right: \"auto\",\r\n // transform: \"scale(1) translateX(-50%)\",\r\n // transformOrigin: \"0% 100%\",\r\n }\r\n default:\r\n return {\r\n position: \"absolute\",\r\n right: `-${cssObject.spacing?.[cssKeys?.xs]}`,\r\n left: \"auto\",\r\n // transform: \"scale(1) translateX(-50%)\",\r\n // transformOrigin: \"0% 100%\",\r\n }\r\n }\r\n };\r\n\r\n const getVertical = (vertical) => {\r\n const getVertical = String(vertical).toLowerCase();\r\n switch (getVertical) {\r\n case \"bottom\":\r\n return {\r\n position: \"absolute\",\r\n bottom: `-${cssObject.spacing?.[cssKeys?.xs]}`,\r\n auto: \"auto\",\r\n };\r\n default:\r\n return {\r\n position: \"absolute\",\r\n top: `-${cssObject.spacing?.[cssKeys?.xs]}`,\r\n bottom: \"auto\",\r\n };\r\n }\r\n };\r\n\r\n const getStyleMode = (mode) => {\r\n const getStyle = String(mode).toLowerCase();\r\n switch (getStyle) {\r\n case \"dot\":\r\n return {\r\n minWidth: cssObject.spacing?.[cssKeys?.sm],\r\n padding: \"0px\",\r\n margin: \"0px\",\r\n height:cssObject.spacing?.[cssKeys?.sm],\r\n border: \"none\",\r\n };\r\n default:\r\n return null;\r\n }\r\n };\r\n\r\n return{\r\n classesName,\r\n style,\r\n styleSx,\r\n }\r\n}","var __WEBPACK_NAMESPACE_OBJECT__ = require(\"@cbmisorg/icons\");","import React, { forwardRef, useContext } from \"react\";\r\nimport { ContextThemeProvider, styleFunction } from \"@cbmisorg/styles\";\r\nimport ChipStyle from \"./ChipStyle\";\r\nimport ErrorBoundary from \"../../_helper/errorHandeling/ErrorBoundary/ErrorBoundary\";\r\nimport { Avatar } from \"@cbmisorg/material\";\r\nimport { Icon } from \"@cbmisorg/icons\";\r\n\r\nconst Chip = forwardRef((/**@type {any}*/props, ref) => {\r\n const { label, mode, size, color, avatar, endAvatar,icon, endIcon, sx, hidden, disabled, dir, className, ...rest } = props;\r\n const theTheme = useContext(ContextThemeProvider);\r\n const {classesName, style, styleSx} = ChipStyle(theTheme);\r\n const classes = style();\r\n const classesSx = styleSx({ sx, label, mode, size, color, avatar, endAvatar,icon, endIcon });\r\n\r\n const itemClasses = styleFunction.getClassName(classes?.[classesName?.chip], classesSx?.[classesName?.chip], classesSx?.[classesName?.sx], styleFunction.CheckDirectionItem(dir),styleFunction.CheckDisabledItem(disabled), styleFunction.CheckHiddenItem(hidden),styleFunction.checkExistsMargin(rest),styleFunction.checkExistsPadding(rest), className);\r\n\r\n return (\r\n \r\n
\r\n {avatar? (\r\n \r\n {avatar?.props?.children}\r\n \r\n ) : icon?(\r\n \r\n ):\"\"\r\n }\r\n {label || props?.children}
\r\n {endAvatar? (\r\n \r\n {endAvatar?.props?.children}\r\n \r\n ) : endIcon?( ):\"\"\r\n }\r\n \r\n
\r\n );\r\n});\r\n\r\nexport default Chip;\r\n","import {\r\n StyleBuilder,\r\n styleVariables,\r\n cssKeys,\r\n mainTheme,\r\n styleFunction,\r\n} from \"@cbmisorg/styles\";\r\n\r\nexport default(objThemeInfo)=>{\r\n const cssObject = objThemeInfo?.cssObject || mainTheme?.cssObject;\r\n\r\n const classesName = {\r\n chip: `${styleVariables?.prefixDefaultClassName}_chip`,\r\n chip_content: `${styleVariables?.prefixDefaultClassName}_chip_content`,\r\n shape_circle: `${styleVariables?.prefixDefaultClassName}_shape_circle`,\r\n sx:`${styleVariables?.prefixDefaultClassName}_chip_sx`\r\n }\r\n\r\n const style = StyleBuilder({\r\n blnRandomPrefix: false,\r\n blnIsDefaultStyle: true,\r\n blnCbmisStyle: true,\r\n objStyles: {\r\n [classesName?.chip]: {\r\n display: \"inline-flex\",\r\n flexDirection: \"row\",\r\n border: \"none\",\r\n cursor: \"default\",\r\n outline: \"none\",\r\n padding: \"0\",\r\n whiteSpace: \"nowrap\",\r\n alignItems: \"center\",\r\n verticalAlign: \"middle\",\r\n textDecoration: \"none\",\r\n justifyContent: \"center\",\r\n },\r\n [classesName?.chip_contain]: {\r\n display: cssObject?.display?.flex,\r\n width: cssObject?.size?.full,\r\n height: cssObject?.size?.full,\r\n justifyContent: \"center\",\r\n alignItems: \"center\",\r\n textAlign: \"center\",\r\n verticalAlign: \"middle\",\r\n margin: cssObject.spacing?.auto,\r\n padding: cssObject.spacing?.auto,\r\n position: cssObject.position?.absolute,\r\n top: \"0\",\r\n left: \"0\",\r\n zIndex: \"var(--cbmis-z-index-1)\",\r\n color: cssObject?.color?.currentColor,\r\n },\r\n },\r\n });\r\n\r\n const styleSx = StyleBuilder({\r\n blnRandomPrefix: true,\r\n blnIsDefaultStyle: false,\r\n blnCbmisStyle: true,\r\n objStyles: {\r\n [classesName?.chip]: (props) => {\r\n return{\r\n borderRadius: cssObject?.border?.[cssKeys?.rounded]?.lg,\r\n margin: cssObject.spacing?.[cssKeys?.xs],\r\n padding: `0 ${cssObject.spacing?.[cssKeys?.xs]}`,\r\n color:String(props?.mode).toLowerCase() === \"outlined\"?cssObject?.color?.[cssKeys?.bodyColor] : cssObject?.color?.[cssKeys?.light],\r\n border: String(props.mode).toLowerCase() !==\"outlined\"?\"none\": `${cssObject?.size?.[cssKeys?.border_xs]} ${cssObject?.border?.[cssKeys?.border]?.solid} ${styleFunction.checkColorReturnValue(props?.color || cssObject?.color?.[cssKeys?.currentColor])}`,\r\n width: \"fitContent\",\r\n backgroundColor:String(props?.mode).toLowerCase() === \"outlined\"?\"transpose\": styleFunction.checkColorReturnValue(props?.color || cssObject?.color?.[cssKeys?.bodyColorBgDark]),\r\n height: cssObject.size?.[cssKeys?.[`item_${props?.size}`]] || cssObject.size?.[cssKeys?.item_sm],\r\n fontSize: \"12px\" || cssObject?.text.size?.[cssKeys?.[props?.size]] || cssObject?.text.size?.[cssKeys?.sm],\r\n \r\n }\r\n },\r\n [classesName.sx]: (props) => {\r\n return {...props?.sx}\r\n },\r\n },\r\n });\r\n\r\n\r\n return{\r\n classesName,\r\n style,\r\n styleSx,\r\n }\r\n}","import { StyleBuilder } from \"@cbmisorg/styles\";\r\n\r\nexport const style = StyleBuilder({\r\n blnRandomPrefix: false,\r\n blnIsDefaultStyle: true,\r\n blnCbmisStyle: true,\r\n objStyles: {\r\n cbmis_counter: {\r\n font: \"700 50px 'Source Code Pro', monospace\",\r\n display: \"block\",\r\n textAlign: \"center\",\r\n },\r\n },\r\n});\r\n\r\nexport const styleSx = StyleBuilder({\r\n blnRandomPrefix: true,\r\n blnIsDefaultStyle: false,\r\n blnCbmisStyle: true,\r\n objStyles: {\r\n cbmis_counter_sx: (props) => {\r\n return props?.sx;\r\n },\r\n },\r\n});\r\n","import React, { forwardRef, useEffect, useState } from \"react\";\r\nimport { styleFunction } from \"@cbmisorg/styles\";\r\nimport { style, styleSx } from \"./CounterStyle\";\r\n\r\nconst Counter = forwardRef((props,ref) =>{\r\n const { intCount=100, intStep=1, intSeconds = 1, sx, blnCountdown, hidden, disabled, dir, className, ...rest } = props;\r\n const classes = style();\r\n const classesSx = styleSx(props);\r\n const count = parseInt(intCount) || 100;\r\n const [counterState, setCounterState] = useState(blnCountdown?count:0);\r\n\r\n const getRestProps = () => {\r\n const newRest = styleFunction.filterPaddingAndMargin(rest);\r\n return { ...newRest };\r\n };\r\n\r\n useEffect(() => {}, [count,sx, blnCountdown, hidden, disabled, dir, className]);\r\n\r\n useEffect(() => {\r\n let myInterval = setInterval(() => {\r\n if(blnCountdown && counterState !==0 ){\r\n setCounterState(counterState - intStep)\r\n }else if(!blnCountdown && counterState < count ){\r\n setCounterState(counterState + intStep)\r\n }\r\n }, intSeconds * 1000)\r\n return () => {\r\n clearInterval(myInterval)\r\n }\r\n });\r\n\r\n return (\r\n \r\n \r\n {counterState}\r\n
\r\n \r\n );\r\n});\r\n\r\nexport default Counter;\r\n"," import {\r\n StyleBuilder,\r\n styleVariables,\r\n cssKeys,\r\n mainTheme,\r\n styleFunction,\r\n } from \"@cbmisorg/styles\";\r\n\r\n export default(objThemeInfo)=>{\r\n const cssObject = objThemeInfo?.cssObject || mainTheme?.cssObject;\r\n const currentBaseSize = objThemeInfo?.currentBaseSize || mainTheme?.currentBaseSize;\r\n\r\n const classesName = {\r\n modal_container: `${styleVariables?.prefixDefaultClassName}_modal_container`,\r\n modal_out: `${styleVariables?.prefixDefaultClassName}_modal_out`,\r\n modal: `${styleVariables?.prefixDefaultClassName}_modal`,\r\n modal_close_btn: `${styleVariables?.prefixDefaultClassName}_modal_close_btn`,\r\n modal_details: `${styleVariables?.prefixDefaultClassName}_modal_details`,\r\n modal_header: `${styleVariables?.prefixDefaultClassName}_modal_header`,\r\n modal_header_content: `${styleVariables?.prefixDefaultClassName}_modal_header_content`,\r\n modal_body: `${styleVariables?.prefixDefaultClassName}_modal_body`,\r\n modal_footer: `${styleVariables?.prefixDefaultClassName}_modal_footer`,\r\n sx:`${styleVariables?.prefixDefaultClassName}_modal_sx`\r\n }\r\n\r\n const getWidth = (width) => {\r\n switch (String(width).toLowerCase()) {\r\n case \"xl\":\r\n return {\r\n width: cssObject?.size?.[cssKeys?.xl]\r\n }\r\n case \"lg\":\r\n return {\r\n width: cssObject?.size?.[cssKeys?.lg]\r\n }\r\n case \"md\":\r\n return {\r\n width: cssObject?.size?.[cssKeys?.md]\r\n }\r\n case \"sm\":\r\n return {\r\n width: cssObject?.size?.[cssKeys?.sm]\r\n }\r\n case \"sm\":\r\n return {\r\n width: cssObject?.size?.[cssKeys?.xs]\r\n }\r\n case \"fluid\":\r\n return {\r\n width: cssObject?.size?.[cssKeys?.full]\r\n }\r\n case \"half\":\r\n return {\r\n width: cssObject?.size?.[cssKeys?.half]\r\n }\r\n default:\r\n return {\r\n width: cssObject?.size?.[cssKeys?.md],\r\n sm:{\r\n width: cssObject?.size?.[cssKeys?.[\"11/12\"]],\r\n }\r\n }\r\n }\r\n };\r\n\r\n const style = StyleBuilder({\r\n blnRandomPrefix: false,\r\n blnIsDefaultStyle: true,\r\n blnCbmisStyle: true,\r\n objStyles: {\r\n [classesName?.modal_container]:{\r\n position: \"fixed\",\r\n top: \"0\",\r\n left: \"0\",\r\n zIndex: 1201,\r\n display: \"flex\",\r\n justifyContent: \"center\",\r\n alignItems: \"flex-start\",\r\n width: \"100%\",\r\n height: \"100%\",\r\n overflow: \"auto\",\r\n background: \"rgba(0,0,0,0.75)\",\r\n padding: \"15% auto\",\r\n filter: \"blur('8px')\",\r\n },\r\n [classesName?.modal_out]:{\r\n position: \"fixed\",\r\n top: \"0\",\r\n left: \"0\",\r\n width: \"99%\",\r\n height: \"100%\",\r\n background: \"transparent\",\r\n padding: \"15% auto\",\r\n margin: \"auto\",\r\n },\r\n [classesName?.modal]:{\r\n height: \"auto\",\r\n maxHeight: \"90%\",\r\n display: \"block\",\r\n margin: \"auto\",\r\n position: \"static\",\r\n overflow: \"auto\",\r\n zIndex: 1,\r\n },\r\n [classesName?.modal_close_btn]:{\r\n position: \"absolute\",\r\n right: \"0px\",\r\n border: \"none\",\r\n margin: \"0\",\r\n padding: \"0px\",\r\n background: \"transparent\",\r\n color: \"currentColor\",\r\n transition: \".2s\",\r\n cursor: \"pointer\",\r\n },\r\n [classesName?.modal_details]:{\r\n position: \"relative\",\r\n textAlign: \"center\",\r\n },\r\n [classesName?.modal_header]:{\r\n position: \"relative\",\r\n padding: \"0px\",\r\n paddingBottom: cssObject?.spacing?.[cssKeys?.sm],\r\n fontSize: cssObject?.text?.size?.[cssKeys?.subtitle1],\r\n fontWeight: cssObject?.text?.fontWeight?.[cssKeys?.fontWeight_md],\r\n minHeight: cssObject?.spacing?.[cssKeys?.md],\r\n color: cssObject?.color?.gray,\r\n borderBottom: `${cssObject?.size?.[cssKeys?.border_xs]} ${cssObject?.border?.[cssKeys?.border]?.solid} ${styleFunction.checkColorReturnValue(cssObject?.color?.[cssKeys?.borderColor])}`,\r\n marginTop: \"0px\",\r\n width: \"100%\",\r\n display:\"flex\",\r\n alignItems:\"center\",\r\n justifyContent:\"center\"\r\n },\r\n [classesName?.modal_header_content]:{\r\n position: \"relative\",\r\n width: \"max-content\",\r\n display:\"block\"\r\n },\r\n [classesName?.modal_body]:{\r\n position: \"relative\",\r\n marginTop: cssObject?.spacing?.[cssKeys?.xs],\r\n padding: cssObject?.spacing?.[cssKeys?.sm],\r\n textAlign: \"start\",\r\n },\r\n [classesName?.modal_footer]:{\r\n position: \"relative\",\r\n top: cssObject?.spacing?.[cssKeys?.sm],\r\n marginTop: cssObject?.spacing?.[cssKeys?.md],\r\n marginBottom: cssObject?.spacing?.[cssKeys?.sm],\r\n color: cssObject?.color?.gray,\r\n fontSize: cssObject?.text?.size?.[cssKeys?.body2],\r\n },\r\n },\r\n });\r\n\r\n const styleModalSx = StyleBuilder({\r\n blnRandomPrefix: true,\r\n blnIsDefaultStyle: false,\r\n blnCbmisStyle: true,\r\n objStyles: {\r\n [classesName?.modal]: (props) => {\r\n return{\r\n color: cssObject?.color?.bodyColor,\r\n background:cssObject?.color?.bodyColorBg,\r\n padding: `${cssObject?.spacing?.[cssKeys?.md]} ${cssObject?.spacing?.[cssKeys?.sm]}`,\r\n borderRadius: cssObject?.border?.[cssKeys?.rounded]?.xs,\r\n bottom: cssObject?.spacing?.[cssKeys?.lg],\r\n boxShadow: cssObject?.boxShadow?.[cssKeys?.lg],\r\n ...getWidth(props?.size)\r\n }\r\n },\r\n [classesName?.sx]: (props) => {\r\n return {\r\n ...props?.sx,\r\n };\r\n },\r\n },\r\n });\r\n\r\n const styleModalHeaderSx = StyleBuilder({\r\n blnRandomPrefix: true,\r\n blnIsDefaultStyle: false,\r\n blnCbmisStyle: true,\r\n objStyles: {\r\n [classesName?.modal_close_btn]:{\r\n fontSize: cssObject?.text?.size?.[cssKeys?.subtitle1],\r\n \"&hover\":{\r\n background:cssObject?.color?.bodyColorBg,\r\n borderColor: cssObject?.color?.bodyColorDark,\r\n color: cssObject?.color?.error,\r\n transform: \"translateY(-3px)\",\r\n\r\n }\r\n },\r\n [classesName?.sx]: (props) => {\r\n return props?.sx;\r\n },\r\n },\r\n });\r\n\r\n const styleModalBodySx = StyleBuilder({\r\n blnRandomPrefix: true,\r\n blnIsDefaultStyle: false,\r\n blnCbmisStyle: true,\r\n objStyles: {\r\n [classesName?.sx]: (props) => {\r\n return props?.sx;\r\n },\r\n },\r\n });\r\n\r\n const styleModalFooterSx = StyleBuilder({\r\n blnRandomPrefix: true,\r\n blnIsDefaultStyle: false,\r\n blnCbmisStyle: true,\r\n objStyles: {\r\n [classesName?.sx]: (props) => {\r\n return props?.sx;\r\n },\r\n },\r\n });\r\n\r\n\r\n\r\n return{\r\n classesName,\r\n style,\r\n styleModalSx,\r\n styleModalHeaderSx,\r\n styleModalBodySx,\r\n styleModalFooterSx,\r\n getWidth\r\n }\r\n }\r\n\r\n","import React, { forwardRef, useContext, useId } from \"react\";\r\nimport { ContextThemeProvider, styleFunction } from \"@cbmisorg/styles\";\r\nimport ModalStyle from \"./ModalStyle\";\r\nimport ErrorBoundary from \"../../_helper/errorHandeling/ErrorBoundary/ErrorBoundary\";\r\n\r\nconst ModalContainer = forwardRef((/**@type {any}*/props, ref) => {\r\n const { eventClose, size=\"md\", sx, hidden, disabled, dir, className, id, ...rest } = props;\r\n const theTheme = useContext(ContextThemeProvider);\r\n const {classesName, style, styleModalSx} = ModalStyle(theTheme);\r\n const classes = style();\r\n const classesSx = styleModalSx({ sx, size });\r\n const idModal =id || useId().replace(/:/g, \"\");\r\n\r\n const itemClasses = styleFunction.getClassName(classes?.[classesName?.modal], classesSx?.[classesName?.modal], classesSx?.[classesName?.sx], styleFunction.CheckDirectionItem(dir),styleFunction.CheckDisabledItem(disabled), styleFunction.CheckHiddenItem(hidden),styleFunction.checkExistsMargin(rest),styleFunction.checkExistsPadding(rest), className);\r\n\r\n return (\r\n \r\n
\r\n
\r\n
\r\n \r\n {React.Children.map(props.children, child => React.cloneElement(child, { handleClose: eventClose }) )}\r\n \r\n
\r\n
\r\n
\r\n )\r\n});\r\n\r\nexport default ModalContainer;\r\n","import React, { forwardRef, useContext, useId } from \"react\";\r\nimport { ContextThemeProvider, styleFunction } from \"@cbmisorg/styles\";\r\nimport ModalStyle from \"./ModalStyle\";\r\nimport ErrorBoundary from \"../../_helper/errorHandeling/ErrorBoundary/ErrorBoundary\";\r\nimport ModalContainer from \"./ModalContainer\";\r\n\r\nconst Modal = forwardRef((/**@type {any}*/props, ref) => {\r\n const { open } = props;\r\n \r\n return open ? (\r\n \r\n ) : null;\r\n});\r\n\r\nexport default Modal;\r\n","import React, { forwardRef, useContext } from \"react\";\r\nimport { ContextThemeProvider, styleFunction } from \"@cbmisorg/styles\";\r\nimport { Icon } from \"@cbmisorg/icons\";\r\nimport ModalStyle from \"./ModalStyle\";\r\nimport ErrorBoundary from \"../../_helper/errorHandeling/ErrorBoundary/ErrorBoundary\";\r\n\r\nconst ModalHeader = forwardRef((/**@type {any}*/props, ref) => {\r\n let { sx, hidden, disabled, dir, className, id, closeIcon, handleClose=null, ...rest } = props;\r\n const theTheme = useContext(ContextThemeProvider);\r\n const {classesName, style, styleModalHeaderSx} = ModalStyle(theTheme);\r\n const classes = style();\r\n const classesSx = styleModalHeaderSx({ sx });\r\n const itemClasses = styleFunction.getClassName(classes?.[classesName?.modal_header], classesSx?.[classesName?.sx], styleFunction.CheckDirectionItem(dir),styleFunction.CheckDisabledItem(disabled), styleFunction.CheckHiddenItem(hidden),styleFunction.checkExistsMargin(rest),styleFunction.checkExistsPadding(rest), className);\r\n\r\n return (\r\n \r\n
\r\n \r\n \r\n \r\n {props.children}
\r\n \r\n
\r\n );\r\n});\r\n\r\nexport default ModalHeader;\r\n","import React, { forwardRef, useContext } from \"react\";\r\nimport { ContextThemeProvider, styleFunction } from \"@cbmisorg/styles\";\r\nimport ErrorBoundary from \"../../_helper/errorHandeling/ErrorBoundary/ErrorBoundary\";\r\nimport ModalStyle from \"./ModalStyle\";\r\n\r\nconst ModalBody = forwardRef((/**@type {any}*/props, ref) => {\r\n const { sx, hidden, disabled, dir, className,handleClose=null, ...rest } = props;\r\n const theTheme = useContext(ContextThemeProvider);\r\n const {classesName, style, styleModalBodySx} = ModalStyle(theTheme);\r\n const classes = style();\r\n const classesSx = styleModalBodySx({ sx });\r\n\r\n const itemClasses = styleFunction.getClassName(classes?.[classesName?.modal_body], classesSx?.[classesName?.sx], styleFunction.CheckDirectionItem(dir),styleFunction.CheckDisabledItem(disabled), styleFunction.CheckHiddenItem(hidden),styleFunction.checkExistsMargin(rest),styleFunction.checkExistsPadding(rest), className);\r\n\r\n\r\n return (\r\n \r\n {props.children} \r\n
\r\n );\r\n});\r\n\r\nexport default ModalBody;\r\n","import React, { forwardRef, useContext } from \"react\";\r\nimport { ContextThemeProvider, styleFunction } from \"@cbmisorg/styles\";\r\nimport ModalStyle from \"./ModalStyle\";\r\nimport ErrorBoundary from \"../../_helper/errorHandeling/ErrorBoundary/ErrorBoundary\";\r\n\r\nconst ModalFooter = forwardRef((/**@type {any}*/props, ref) => {\r\n const { sx, hidden, disabled, dir, className,handleClose=null, ...rest } = props;\r\n const theTheme = useContext(ContextThemeProvider);\r\n const {classesName, style, styleModalFooterSx} = ModalStyle(theTheme);\r\n const classes = style();\r\n const classesSx = styleModalFooterSx({sx});\r\n\r\n const itemClasses = styleFunction.getClassName(classes?.[classesName?.modal_footer], classesSx?.[classesName?.sx], styleFunction.CheckDirectionItem(dir),styleFunction.CheckDisabledItem(disabled), styleFunction.CheckHiddenItem(hidden),styleFunction.checkExistsMargin(rest),styleFunction.checkExistsPadding(rest), className);\r\n\r\n return (\r\n \r\n {props.children} \r\n
\r\n );\r\n});\r\n\r\nexport default ModalFooter;\r\n","import React, { forwardRef, useContext } from \"react\";\r\nimport { ContextThemeProvider, styleFunction } from \"@cbmisorg/styles\";\r\nimport TypographyStyle from \"./TypographyStyle\";\r\nimport ErrorBoundary from \"../../_helper/errorHandeling/ErrorBoundary/ErrorBoundary\";\r\n\r\nconst Typography = forwardRef((/**@type {any}*/props, ref) => {\r\n const { as, color, sx, hidden, disabled, dir, className, ...rest } = props;\r\n const theTheme = useContext(ContextThemeProvider);\r\n const {classesName, style, styleSx} = TypographyStyle(theTheme);\r\n const classes = style();\r\n const classesSx = styleSx({as, color, sx});\r\n\r\n const itemClasses = styleFunction.getClassName(classes?.[classesName?.typography], classesSx?.[classesName?.sx], styleFunction.CheckDirectionItem(dir),styleFunction.CheckDisabledItem(disabled), styleFunction.CheckHiddenItem(hidden),styleFunction.checkExistsMargin(rest),styleFunction.checkExistsPadding(rest), className);\r\n\r\n return (\r\n \r\n {props.children} \r\n
\r\n );\r\n});\r\n\r\nexport default Typography;\r\n","import {\r\n StyleBuilder,\r\n styleVariables,\r\n cssKeys,\r\n mainTheme,\r\n styleFunction,\r\n} from \"@cbmisorg/styles\";\r\n\r\nexport default(objThemeInfo)=>{\r\n const cssObject = objThemeInfo?.cssObject || mainTheme?.cssObject;\r\n\r\n const classesName = {\r\n typography: `${styleVariables?.prefixDefaultClassName}_typography`,\r\n sx:`${styleVariables?.prefixDefaultClassName}_typography_sx`\r\n }\r\n\r\n const style = StyleBuilder({\r\n blnRandomPrefix: false,\r\n blnIsDefaultStyle: true,\r\n blnCbmisStyle: true,\r\n objStyles: {\r\n [classesName?.typography]: {\r\n display: cssObject?.display?.[cssKeys?.block],\r\n margin: 0,\r\n padding: 0,\r\n whiteSpace: cssObject?.whiteSpace?.[cssKeys?.breakSpaces],\r\n textAlign: cssObject?.side?.[cssKeys?.start],\r\n color: cssObject?.color?.[cssKeys?.bodyColor],\r\n },\r\n },\r\n });\r\n\r\n const styleSx = StyleBuilder({\r\n blnRandomPrefix: true,\r\n blnIsDefaultStyle: false,\r\n blnCbmisStyle: true,\r\n objStyles: {\r\n [classesName?.sx]: (props) => {\r\n return {\r\n ...getFontSizeAsReturnValue(props?.as),\r\n ...props?.sx,\r\n color: styleFunction.checkColorReturnValue(props?.color || props?.sx?.color || \"currentColor\"),\r\n \r\n };\r\n },\r\n }\r\n });\r\n\r\n\r\n const getFontSizeAsReturnValue = (as=\"body1\") => {\r\n const getSize = String(as).toLowerCase();\r\n switch (getSize) {\r\n case \"h1\":\r\n return {\r\n fontSize: cssObject?.text?.size?.[cssKeys?.h1],\r\n fontWeight: cssObject?.text?.fontWeight?.[cssKeys?.fontWeight_xl],\r\n };\r\n case \"h2\":\r\n return {\r\n fontSize: cssObject?.text?.size?.[cssKeys?.h2],\r\n fontWeight: cssObject?.text?.fontWeight?.[cssKeys?.fontWeight_xl],\r\n };\r\n case \"h3\":\r\n return {\r\n fontSize: cssObject?.text?.size?.[cssKeys?.h3],\r\n fontWeight: cssObject?.text?.fontWeight?.[cssKeys?.fontWeight_xl],\r\n };\r\n case \"h4\":\r\n return {\r\n fontSize: cssObject?.text?.size?.[cssKeys?.h4],\r\n fontWeight: cssObject?.text?.fontWeight?.[cssKeys?.fontWeight_lg],\r\n };\r\n case \"h5\":\r\n return {\r\n fontSize: cssObject?.text?.size?.[cssKeys?.h5],\r\n fontWeight: cssObject?.text?.fontWeight?.[cssKeys?.fontWeight_lg],\r\n };\r\n case \"h6\":\r\n return {\r\n fontSize: cssObject?.text?.size?.[cssKeys?.h6],\r\n fontWeight: cssObject?.text?.fontWeight?.[cssKeys?.fontWeight_lg],\r\n };\r\n case \"subtitle1\":\r\n return {\r\n fontSize: cssObject?.text?.size?.[cssKeys?.subtitle1],\r\n fontWeight: cssObject?.text?.fontWeight?.[cssKeys?.fontWeight_md],\r\n };\r\n case \"subtitle2\":\r\n return {\r\n fontSize: cssObject?.text?.size?.[cssKeys?.subtitle2],\r\n fontWeight: cssObject?.text?.fontWeight?.[cssKeys?.fontWeight_md],\r\n };\r\n case \"subtitle3\":\r\n return {\r\n fontSize: cssObject?.text?.size?.[cssKeys?.subtitle3],\r\n fontWeight: cssObject?.text?.fontWeight?.[cssKeys?.fontWeight_md],\r\n };\r\n case \"body1\":\r\n return {\r\n fontSize: cssObject?.text?.size?.[cssKeys?.body1],\r\n fontWeight: cssObject?.text?.fontWeight?.[cssKeys?.fontWeight_xs],\r\n };\r\n case \"body2\":\r\n return {\r\n fontSize: cssObject?.text?.size?.[cssKeys?.body2],\r\n fontWeight: cssObject?.text?.fontWeight?.[cssKeys?.fontWeight_xs],\r\n };\r\n case \"body3\":\r\n return {\r\n fontSize: cssObject?.text?.size?.[cssKeys?.body3],\r\n fontWeight: cssObject?.text?.fontWeight?.[cssKeys?.fontWeight_xs],\r\n };\r\n case \"caption\":\r\n return {\r\n fontSize: cssObject?.text?.size?.[cssKeys?.caption],\r\n fontWeight: cssObject?.text?.fontWeight?.[cssKeys?.fontWeight_xs],\r\n };\r\n case \"overline\":\r\n return {\r\n fontSize:cssObject?.text?.size?.[cssKeys?.overline],\r\n fontWeight: cssObject?.text?.fontWeight?.[cssKeys?.fontWeight_fontWeight_2xs],\r\n letterSpacing: cssObject?.spacing?.[cssKeys?.xs],\r\n textTransform: cssObject?.text?.[cssKeys?.transform]?.uppercase,\r\n };\r\n default:\r\n return {\r\n fontSize: cssObject?.text?.size?.[cssKeys?.body1],\r\n fontWeight: cssObject?.text?.fontWeight?.[cssKeys?.fontWeight_sm],\r\n };\r\n }\r\n };\r\n\r\n return{\r\n classesName,\r\n style,\r\n styleSx,\r\n }\r\n}"," import {\r\n StyleBuilder,\r\n styleVariables,\r\n cssKeys,\r\n mainTheme,\r\n styleFunction,\r\n } from \"@cbmisorg/styles\";\r\n\r\n export default(objThemeInfo)=>{\r\n const cssObject = objThemeInfo?.cssObject || mainTheme?.cssObject;\r\n\r\n const classesName = {\r\n table_contenter: `${styleVariables?.prefixDefaultClassName}_table_contenter`,\r\n mobile_mode_contenter: `${styleVariables?.prefixDefaultClassName}_mobile_mode_contenter`,\r\n table: `${styleVariables?.prefixDefaultClassName}_table`,\r\n table_head: `${styleVariables?.prefixDefaultClassName}_table_head`,\r\n table_body: `${styleVariables?.prefixDefaultClassName}_table_body`,\r\n table_footer: `${styleVariables?.prefixDefaultClassName}_table_footer`,\r\n table_row: `${styleVariables?.prefixDefaultClassName}_table_row`,\r\n table_cell: `${styleVariables?.prefixDefaultClassName}_table_cell`,\r\n\r\n sx:`${styleVariables?.prefixDefaultClassName}_table_sx`\r\n }\r\n const style = StyleBuilder({\r\n blnRandomPrefix: false,\r\n blnIsDefaultStyle: true,\r\n blnCbmisStyle: true,\r\n objStyles: {\r\n [classesName?.table_contenter]:{\r\n display:\"block\",\r\n maxHeight: \"100%\",\r\n position: \"relative\",\r\n margin: \"auto\",\r\n width: \"100%\",\r\n overflow:\"auto\"\r\n },\r\n [classesName?.mobile_mode_contenter]:{\r\n maxHeight: \"95%\",\r\n position: \"relative\",\r\n margin: \"auto\",\r\n width: \"99%\",\r\n },\r\n [classesName?.table]:{\r\n width: \"max-content\",\r\n minWidth:\"100%\",\r\n borderCollapse: \"collapse\",\r\n padding: \"0px\",\r\n margin: \"auto\",\r\n textAlign: \"center\",\r\n tableLayout:\"auto\",\r\n borderSpacing: \"0px\",\r\n position: \"relative\",\r\n border:\"none\",\r\n outline:\"none\",\r\n\r\n [`.${classesName?.table_head}`]:{\r\n position: \"sticky\",\r\n top: \"0px\",\r\n },\r\n [`.${classesName?.table_footer}`]:{\r\n position: \"sticky\",\r\n top: \"0px\",\r\n },\r\n },\r\n [classesName?.table_head]:{\r\n [`.${classesName?.table_cell}`]:{\r\n fontWeight: cssObject?.fontWeight?.[cssKeys?.fontWeight_md],\r\n }\r\n },\r\n [classesName?.table_footer]:{\r\n [`.${classesName?.table_cell}`]:{\r\n fontWeight: cssObject?.fontWeight?.[cssKeys?.fontWeight_md],\r\n }\r\n }\r\n },\r\n });\r\n\r\n const styleTableSx = StyleBuilder({\r\n blnRandomPrefix: true,\r\n blnIsDefaultStyle: false,\r\n blnCbmisStyle: true,\r\n objStyles: {\r\n [classesName?.table]:{\r\n borderRadius: cssObject?.border?.[cssKeys?.rounded]?.xs,\r\n [`.${classesName?.table_body}`]:{\r\n [`.${classesName?.table_row}`]:{\r\n background: cssObject?.color?.white,\r\n borderBottom: `1px ${cssObject?.border?.[cssKeys?.border]?.solid} ${styleFunction.checkColorReturnValue(cssObject?.color?.[cssKeys?.borderColor])}`,\r\n padding: cssObject?.spacing?.[cssKeys?.sm],\r\n },\r\n },\r\n [`.${classesName?.table_cell}`]:{\r\n padding:cssObject?.spacing?.[cssKeys?.sm],\r\n height: cssObject?.size?.baseSize,\r\n // border: `${cssObject?.size?.[cssKeys?.border_xs]} ${cssObject?.border?.[cssKeys?.border]?.solid} ${styleFunction.checkColorReturnValue(cssObject?.color?.[cssKeys?.borderColor])}`,\r\n fontSize: cssObject?.text?.size?.[cssKeys?.body1],\r\n fontWeight: cssObject?.fontWeight?.[cssKeys?.fontWeight_sm],\r\n textAlign: \"center\",\r\n }\r\n },\r\n [classesName?.sx]: (props) => {\r\n return {\r\n ...props?.sx,\r\n color: styleFunction.checkColorReturnValue(props?.color || props?.sx?.color || cssObject?.color?.[cssKeys?.bodyColor]),\r\n\r\n };\r\n },\r\n },\r\n });\r\n\r\n const styleTableRowSx = StyleBuilder({\r\n blnRandomPrefix: true,\r\n blnIsDefaultStyle: false,\r\n blnCbmisStyle: true,\r\n objStyles: {\r\n [classesName?.sx]: (props) => {\r\n return props?.sx;\r\n },\r\n },\r\n });\r\n\r\n const styleTableHeadSx = StyleBuilder({\r\n blnRandomPrefix: true,\r\n blnIsDefaultStyle: false,\r\n blnCbmisStyle: true,\r\n objStyles: {\r\n [classesName?.table_head]:{\r\n [`.${classesName?.table_row}`]:{\r\n fontWeight: cssObject?.text?.fontWeight?.[cssKeys?.fontWeight_md],\r\n background: cssObject?.color?.bodyColorBgLight,\r\n },\r\n },\r\n [classesName?.sx]: (props) => {\r\n return props?.sx;\r\n },\r\n },\r\n });\r\n\r\n const styleTableBodySx = StyleBuilder({\r\n blnRandomPrefix: true,\r\n blnIsDefaultStyle: false,\r\n blnCbmisStyle: true,\r\n objStyles: {\r\n [classesName?.sx]: (props) => {\r\n return props?.sx;\r\n },\r\n },\r\n });\r\n\r\n const styleTableCellSx = StyleBuilder({\r\n blnRandomPrefix: true,\r\n blnIsDefaultStyle: false,\r\n blnCbmisStyle: true,\r\n objStyles: {\r\n [classesName?.sx]: (props) => {\r\n return props?.sx;\r\n },\r\n },\r\n });\r\n\r\n const styleTableFooterSx = StyleBuilder({\r\n blnRandomPrefix: true,\r\n blnIsDefaultStyle: false,\r\n blnCbmisStyle: true,\r\n objStyles: {\r\n [classesName?.table_footer]:{\r\n [`.${classesName?.table_cell}`]:{\r\n fontWeight: cssObject?.fontWeight?.[cssKeys?.fontWeight_md],\r\n }\r\n },\r\n [classesName?.sx]: (props) => {\r\n return props?.sx;\r\n },\r\n },\r\n });\r\n\r\n return{\r\n classesName,\r\n style,\r\n styleTableSx,\r\n styleTableRowSx,\r\n styleTableHeadSx,\r\n styleTableBodySx,\r\n styleTableCellSx,\r\n styleTableFooterSx\r\n }\r\n }","import React, { forwardRef, useContext, useId } from \"react\";\r\nimport { ContextThemeProvider, styleFunction } from \"@cbmisorg/styles\";\r\nimport ErrorBoundary from \"../../_helper/errorHandeling/ErrorBoundary/ErrorBoundary\";\r\nimport TableStyle from \"./TableStyle\";\r\n\r\nconst Table = forwardRef((/**@type {any}*/props,ref) => {\r\n const { blnMobileMode, sx, id, hidden, disabled, dir, className, ...rest } = props;\r\n const theTheme = useContext(ContextThemeProvider);\r\n const {classesName, style, styleTableSx} = TableStyle(theTheme);\r\n const classes = style();\r\n const classesSx = styleTableSx({sx, blnMobileMode:blnMobileMode});\r\n const comID = id || String(useId()).slice(1,-1)\r\n\r\n const itemClasses = styleFunction.getClassName( classes?.[classesName?.table], classesSx?.[classesName?.table], classesSx?.[classesName?.sx], styleFunction.CheckDirectionItem(dir),styleFunction.CheckDisabledItem(disabled), styleFunction.CheckHiddenItem(hidden),styleFunction.checkExistsMargin(rest),styleFunction.checkExistsPadding(rest), className);\r\n\r\n return (\r\n \r\n
\r\n {props.children} \r\n
\r\n
\r\n );\r\n});\r\n\r\nexport default Table;\r\n","import React, { forwardRef, useContext, useId } from \"react\";\r\nimport { ContextThemeProvider, styleFunction } from \"@cbmisorg/styles\";\r\nimport TableStyle from \"./TableStyle\";\r\nimport ErrorBoundary from \"../../_helper/errorHandeling/ErrorBoundary/ErrorBoundary\";\r\n\r\nconst TableHead= forwardRef((/**@type {any}*/props,ref) =>{\r\n const { sx,id, hidden, disabled, dir, className, ...rest } = props;\r\n const theTheme = useContext(ContextThemeProvider);\r\n const {classesName, style, styleTableHeadSx} = TableStyle(theTheme);\r\n const classes = style();\r\n const classesSx = styleTableHeadSx({sx});\r\n const comID = id || String(useId()).slice(1,-1)\r\n\r\n const itemClasses = styleFunction.getClassName(classes?.[classesName?.table_head], classesSx?.[classesName?.table_head], classesSx?.[classesName?.sx], styleFunction.CheckDirectionItem(dir),styleFunction.CheckDisabledItem(disabled), styleFunction.CheckHiddenItem(hidden),styleFunction.checkExistsMargin(rest),styleFunction.checkExistsPadding(rest), className);\r\n\r\n return (\r\n \r\n {props.children} \r\n \r\n );\r\n});\r\n\r\nexport default TableHead;\r\n","import React, { forwardRef, useContext, useId } from \"react\";\r\nimport { ContextThemeProvider, styleFunction } from \"@cbmisorg/styles\";\r\nimport TableStyle from \"./TableStyle\";\r\nimport ErrorBoundary from \"../../_helper/errorHandeling/ErrorBoundary/ErrorBoundary\";\r\n\r\nconst TableBody = forwardRef((/**@type {any}*/props,ref) =>{\r\n const { sx, hidden, disabled, dir, id, className, ...rest } = props;\r\n const theTheme = useContext(ContextThemeProvider);\r\n const {classesName, styleTableBodySx} = TableStyle(theTheme);\r\n const classesSx = styleTableBodySx({sx});\r\n const comID = id || String(useId()).slice(1,-1)\r\n\r\n\r\n const itemClasses = styleFunction.getClassName(classesName?.table_body ,classesSx?.[classesName?.sx], styleFunction.CheckDirectionItem(dir),styleFunction.CheckDisabledItem(disabled), styleFunction.CheckHiddenItem(hidden),styleFunction.checkExistsMargin(rest),styleFunction.checkExistsPadding(rest), className);\r\n\r\n return (\r\n \r\n {props.children} \r\n \r\n );\r\n\r\n});\r\n\r\nexport default TableBody;\r\n","import React, { forwardRef, useContext, useId } from \"react\";\r\nimport { ContextThemeProvider, styleFunction } from \"@cbmisorg/styles\";\r\nimport TableStyle from \"./TableStyle\";\r\nimport ErrorBoundary from \"../../_helper/errorHandeling/ErrorBoundary/ErrorBoundary\";\r\n\r\nconst TableFooter = forwardRef((/**@type {any}*/props,ref) => {\r\n const { sx, id, hidden, disabled, dir, className, ...rest } = props;\r\n const theTheme = useContext(ContextThemeProvider);\r\n const {classesName, style, styleTableFooterSx} = TableStyle(theTheme);\r\n const classes = style();\r\n const classesSx = styleTableFooterSx({sx});\r\n const comID = id || String(useId()).slice(1,-1)\r\n\r\n const itemClasses = styleFunction.getClassName(classes?.[classesName?.table_footer], classesSx?.[classesName?.table_footer], classesSx?.[classesName?.sx], styleFunction.CheckDirectionItem(dir),styleFunction.CheckDisabledItem(disabled), styleFunction.CheckHiddenItem(hidden),styleFunction.checkExistsMargin(rest),styleFunction.checkExistsPadding(rest), className);\r\n\r\n return (\r\n \r\n {props.children} \r\n \r\n );\r\n});\r\n\r\nexport default TableFooter;\r\n","import React, { forwardRef, useContext, useId } from \"react\";\r\nimport { ContextThemeProvider, styleFunction } from \"@cbmisorg/styles\";\r\nimport TableStyle from \"./TableStyle\";\r\nimport ErrorBoundary from \"../../_helper/errorHandeling/ErrorBoundary/ErrorBoundary\";\r\n\r\nconst TableRow= forwardRef((/**@type {any}*/props,ref) => {\r\n const { sx, id, hidden, disabled, dir, className, ...rest } = props;\r\n const theTheme = useContext(ContextThemeProvider);\r\n const {classesName, style, styleTableRowSx} = TableStyle(theTheme);\r\n const classesSx = styleTableRowSx({sx});\r\n const comID = id || String(useId()).slice(1,-1)\r\n\r\n const itemClasses = styleFunction.getClassName(classesName?.table_row, classesSx?.[classesName?.sx], styleFunction.CheckDirectionItem(dir),styleFunction.CheckDisabledItem(disabled), styleFunction.CheckHiddenItem(hidden),styleFunction.checkExistsMargin(rest),styleFunction.checkExistsPadding(rest), className);\r\n\r\n return (\r\n \r\n {props.children} \r\n \r\n );\r\n});\r\n\r\nexport default TableRow;\r\n","import React, { forwardRef, useContext, useId } from \"react\";\r\nimport { ContextThemeProvider, styleFunction } from \"@cbmisorg/styles\";\r\nimport TableStyle from \"./TableStyle\";\r\nimport ErrorBoundary from \"../../_helper/errorHandeling/ErrorBoundary/ErrorBoundary\";\r\n\r\nconst TableCell = forwardRef((/**@type {any}*/props,ref) =>{\r\n const { headLabel, rowSpan, colSpan, sx, id, hidden, disabled, dir, className, ...rest } = props;\r\n const theTheme = useContext(ContextThemeProvider);\r\n const {classesName, styleTableCellSx} = TableStyle(theTheme);\r\n const classesSx = styleTableCellSx({sx});\r\n const comID = id || String(useId()).slice(1,-1)\r\n\r\n const itemClasses = styleFunction.getClassName(classesName?.table_cell, classesSx?.[classesName?.sx], styleFunction.CheckDirectionItem(dir),styleFunction.CheckDisabledItem(disabled), styleFunction.CheckHiddenItem(hidden),styleFunction.checkExistsMargin(rest),styleFunction.checkExistsPadding(rest), className);\r\n\r\n return (\r\n \r\n {props.children} \r\n \r\n );\r\n});\r\n\r\nexport default TableCell;\r\n","export const viewAlert = (\r\n strText,\r\n mode = \"info\", //error | info | warning | success | custom\r\n direction,\r\n style = {\r\n backDropColor:null,\r\n title: null,\r\n withoutTitle: false,\r\n containerBk: null,\r\n borderColor: null,\r\n iconColorFill: null,\r\n iconWidth: null,\r\n titleColor: null,\r\n textColor: null,\r\n textAlign: null,\r\n fontSizeTitle: null,\r\n fontSizeTitle_xs: null,\r\n fontSize: null,\r\n fontSize_xs: null,\r\n iconEle: null,\r\n withoutIcon: false,\r\n\r\n closeIconColor: null,\r\n closeIconBk: null,\r\n closeIconBorder: null,\r\n\r\n\r\n closeIconColor_hover: null,\r\n closeIconBk_hover: null,\r\n\r\n headerIconSameLvl_xs: false,\r\n\r\n }\r\n) => {\r\n try {\r\n if (typeof window === \"undefined\" || typeof document === \"undefined\") {\r\n return;\r\n }\r\n //////////////////////////////////////////// constant (FOR INTERNAL COMPARE ) ///////////////////////////////////////////////////\r\n //#region\r\n const xmlns = \"http://www.w3.org/2000/svg\";\r\n const MODE_INFO = \"info\";\r\n const MODE_ERROR = \"error\";\r\n const MODE_WARNING = \"warning\";\r\n const MODE_SUCCESS = \"success\";\r\n const MODE_HELP = \"help\";\r\n const MODE_CUSTOM = \"custom\";\r\n //#endregion\r\n //////////////////////////////////////////// init style ///////////////////////////////////////////////////\r\n //#region\r\n\r\n //info #047dbc #04a8f9 #efeefe #5458f7\r\n //error #d60000 #880300 #feeeef #eb5756\r\n //warning #fec107 #bc910e #fef8e8 #f2c94d\r\n //success #4cb050 #3a833c #e5faf5 #00cc99\r\n if (!style) {\r\n style = {};\r\n }\r\n if(!style?.backDropColor){\r\n style.backDropColor = \"rgba(0, 0, 0, 0.5)\";\r\n }\r\n if (!style?.title) {\r\n if (mode === MODE_INFO) {\r\n style.title = direction === \"rtl\" ? \"معلومة\" : \"Information\";\r\n } else if (mode === MODE_ERROR) {\r\n style.title = direction === \"rtl\" ? \"خطأ\" : \"ERROR\";\r\n } else if (mode === MODE_WARNING) {\r\n style.title = direction === \"rtl\" ? \"تحذير\" : \"Warning\";\r\n } else if (mode === MODE_SUCCESS) {\r\n style.title = direction === \"rtl\" ? \"نجاح\" : \"Success\";\r\n } else if (mode === MODE_HELP) {\r\n style.title = direction === \"rtl\" ? \"مساعدة\" : \"Help\";\r\n } else {\r\n style.title = \"\";\r\n }\r\n }\r\n if (style?.withoutTitle) {\r\n style.title = \"\";\r\n }\r\n if (!style?.containerBk) {\r\n if (mode === MODE_INFO) {\r\n style.containerBk = \"#f1f1fe\";\r\n } else if (mode === MODE_ERROR) {\r\n style.containerBk = \"#feeeef\";\r\n } else if (mode === MODE_WARNING) {\r\n style.containerBk = \"#fefaf3\";\r\n } else if (mode === MODE_SUCCESS) {\r\n style.containerBk = \"#f0faf6\";\r\n } else if (mode === MODE_HELP) {\r\n style.containerBk = \"#fff5ef\";\r\n } else {\r\n style.containerBk = \"#ffffff\";\r\n }\r\n }\r\n if (!style?.borderColor) {\r\n if (mode === MODE_INFO) {\r\n style.borderColor = \"#5458f7\";\r\n } else if (mode === MODE_ERROR) {\r\n style.borderColor = \"#eb5756\";\r\n } else if (mode === MODE_WARNING) {\r\n style.borderColor = \"#ecc243\";\r\n } else if (mode === MODE_SUCCESS) {\r\n style.borderColor = \"#00cc99\";\r\n } else if (mode === MODE_HELP) {\r\n style.borderColor = \"#f48a5c\";\r\n } else {\r\n style.borderColor = \"#666\";\r\n }\r\n }\r\n\r\n if (!style?.iconColorFill) {\r\n if (mode === MODE_INFO) {\r\n style.iconColorFill = \"#5458f7\";\r\n } else if (mode === MODE_ERROR) {\r\n style.iconColorFill = \"#eb5756\";\r\n } else if (mode === MODE_WARNING) {\r\n style.iconColorFill = \"#ecc243\";\r\n } else if (mode === MODE_SUCCESS) {\r\n style.iconColorFill = \"#00cc99\";\r\n } else if (mode === MODE_HELP) {\r\n style.iconColorFill = \"#f48a5c\";\r\n } else {\r\n style.iconColorFill = \"#666\";\r\n }\r\n }\r\n if (!style?.iconWidth) {\r\n style.iconWidth = \"100%\";\r\n }\r\n if (!style?.titleColor) {\r\n if (mode === MODE_INFO) {\r\n style.titleColor = \"#5458f7\";\r\n } else if (mode === MODE_ERROR) {\r\n style.titleColor = \"#eb5756\";\r\n } else if (mode === MODE_WARNING) {\r\n style.titleColor = \"#ecc243\";\r\n } else if (mode === MODE_SUCCESS) {\r\n style.titleColor = \"#00cc99\";\r\n } else if (mode === MODE_HELP) {\r\n style.titleColor = \"#f48a5c\";\r\n } else {\r\n style.titleColor = \"#111\";\r\n }\r\n }\r\n if (!style?.textColor) {\r\n style.textColor = \"#55585c\";\r\n }\r\n if (!style?.textAlign) {\r\n style.textAlign = \"justify\";\r\n }\r\n if (!style?.fontSizeTitle_xs) {\r\n style.fontSizeTitle_xs = style?.fontSizeTitle ? style?.fontSizeTitle : \"20px\";\r\n }\r\n if (!style?.fontSizeTitle) {\r\n style.fontSizeTitle = \"24px\";\r\n }\r\n if (!style?.fontSize_xs) {\r\n style.fontSize_xs = style?.fontSize ? style?.fontSize : \"13px\";\r\n }\r\n if (!style?.fontSize) {\r\n style.fontSize = \"16px\";\r\n }\r\n if(!style?.closeIconColor){\r\n style.closeIconColor = \"#cd3a37\";\r\n }\r\n if(!style?.closeIconBk){\r\n style.closeIconBk = \"#ddd\";\r\n }\r\n if(!style?.closeIconColor_hover){\r\n style.closeIconColor_hover = \"#ddd\";\r\n }\r\n if(!style?.closeIconBk_hover){\r\n style.closeIconBk_hover = \"#cd3a37\";\r\n }\r\n \r\n //#endregion\r\n //////////////////////////////////////////// create header icon ///////////////////////////////////////////////////\r\n //#region\r\n let headerIcon = document.createElementNS(xmlns, \"svg\");\r\n headerIcon.setAttributeNS(null, \"viewBox\", \"1 2 22 20\");\r\n\r\n if (!style?.iconEle) {\r\n const path1 = document.createElementNS(xmlns, \"path\");\r\n path1.setAttributeNS(null, \"d\", \"M0 0h24v24H0z\");\r\n path1.setAttributeNS(null, \"fill\", \"none\");\r\n headerIcon.appendChild(path1);\r\n\r\n if (mode === MODE_INFO) {\r\n const path2 = document.createElementNS(xmlns, \"path\");\r\n path2.setAttributeNS(null, \"d\", \"M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm1 15h-2v-6h2v6zm0-8h-2V7h2v2z\");\r\n headerIcon.appendChild(path2);\r\n } else if (mode === MODE_ERROR) {\r\n const path2 = document.createElementNS(xmlns, \"path\");\r\n path2.setAttributeNS(null, \"d\", \"M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm1 15h-2v-2h2v2zm0-4h-2V7h2v6z\");\r\n headerIcon.appendChild(path2);\r\n } else if (mode === MODE_WARNING) {\r\n const path2 = document.createElementNS(xmlns, \"path\");\r\n path2.setAttributeNS(null, \"d\", \"M1 21h22L12 2 1 21zm12-3h-2v-2h2v2zm0-4h-2v-4h2v4z\");\r\n headerIcon.appendChild(path2);\r\n } else if (mode === MODE_SUCCESS) {\r\n const path2 = document.createElementNS(xmlns, \"path\");\r\n path2.setAttributeNS(null, \"d\", \"M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm-2 15l-5-5 1.41-1.41L10 14.17l7.59-7.59L19 8l-9 9z\");\r\n headerIcon.appendChild(path2);\r\n } else {\r\n const path2 = document.createElementNS(xmlns, \"path\");\r\n path2.setAttributeNS(\r\n null,\r\n \"d\",\r\n \"M19 3H5c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zm-6.99 15c-.7 0-1.26-.56-1.26-1.26 0-.71.56-1.25 1.26-1.25.71 0 1.25.54 1.25 1.25-.01.69-.54 1.26-1.25 1.26zm3.01-7.4c-.76 1.11-1.48 1.46-1.87 2.17-.16.29-.22.48-.22 1.41h-1.82c0-.49-.08-1.29.31-1.98.49-.87 1.42-1.39 1.96-2.16.57-.81.25-2.33-1.37-2.33-1.06 0-1.58.8-1.8 1.48l-1.65-.7C9.01 7.15 10.22 6 11.99 6c1.48 0 2.49.67 3.01 1.52.44.72.7 2.07.02 3.08z\"\r\n );\r\n headerIcon.appendChild(path2);\r\n }\r\n\r\n headerIcon.style.fill = style.iconColorFill;\r\n headerIcon.style.width = style.iconWidth;\r\n } else {\r\n headerIcon = style?.iconEle;\r\n }\r\n if (style?.withoutIcon) {\r\n headerIcon = null;\r\n }\r\n //#endregion\r\n //////////////////////////////////////////// create close icon ///////////////////////////////////////////////////\r\n //#region\r\n const closeIcon = document.createElementNS(xmlns, \"svg\");\r\n closeIcon.setAttributeNS(null, \"viewBox\", \"0 0 24 24\");\r\n const path1 = document.createElementNS(xmlns, \"path\");\r\n path1.setAttributeNS(null, \"d\", \"M0 0h24v24H0z\");\r\n path1.setAttributeNS(null, \"fill\", \"none\");\r\n const path2 = document.createElementNS(xmlns, \"path\");\r\n path2.setAttributeNS(null, \"d\", \"M19 6.41L17.59 5 12 10.59 6.41 5 5 6.41 10.59 12 5 17.59 6.41 19 12 13.41 17.59 19 19 17.59 13.41 12z\");\r\n closeIcon.appendChild(path1);\r\n closeIcon.appendChild(path2);\r\n closeIcon.style.cursor = \"pointer\";\r\n closeIcon.style.fill = style.closeIconColor;\r\n closeIcon.style.width = \"1.5rem\";\r\n closeIcon.style.borderRadius = `50%`;\r\n closeIcon.style.background = style?.closeIconBk;\r\n if(style?.closeIconBorder){\r\n closeIcon.style.border = style?.closeIconBorder;\r\n }\r\n //#endregion\r\n //////////////////////////////////////// root of modal //////////////////////////////////////////////\r\n //#region\r\n const modal = document.createElement(\"div\");\r\n\r\n modal.style.position = \"fixed\";\r\n modal.style.left = \"0px\";\r\n modal.style.top = \"0px\";\r\n modal.style.bottom = \"0px\";\r\n modal.style.right = \"0px\";\r\n modal.style.width = \"100%\";\r\n modal.style.height = \"100%\";\r\n modal.style.margin = \"0px\";\r\n modal.style.padding = \"0px\";\r\n modal.style.backgroundColor = style?.backDropColor;\r\n modal.style.opacity = \"1\";\r\n modal.style.transform = \"scale(1)\";\r\n modal.style.transition = \"visibility 0s linear 0.25s, opacity 0.25s 0s, transform 0.25s\";\r\n modal.style.display = \"flex\";\r\n modal.style.flexDirection = \"row\";\r\n modal.style.justifyContent = \"center\";\r\n modal.style.alignSelf = \"center\";\r\n modal.style.alignItems = \"center\";\r\n modal.style.alignContent = \"center\";\r\n modal.style.flexWrap = \"wrap\";\r\n modal.style.boxSizing = \"border-box\";\r\n modal.style.zIndex = 1301;\r\n modal.style.direction = direction === \"rtl\" ? direction : \"ltr\";\r\n //#endregion\r\n ////////////////////////////////////// container ///////////////////////////////////////////////////\r\n //#region\r\n const modalContainer = document.createElement(\"div\");\r\n modalContainer.animate(\r\n [\r\n {\r\n transform: \"scale(0)\",\r\n opacity: \"0\",\r\n },\r\n {\r\n transform: \"scale(1)\",\r\n opacity: \"1\",\r\n },\r\n ],\r\n {\r\n duration: 200,\r\n iterations: 1,\r\n }\r\n );\r\n modalContainer.style.position = \"relative\";\r\n modalContainer.style.margin = \"0px\";\r\n modalContainer.style.display = \"flex\";\r\n modalContainer.style.flexGrow = \"0\";\r\n modalContainer.style.flexBasis = `${(100 / 12) * (window.innerWidth < 600 ? 10 : 8)}%`;\r\n modalContainer.style.width = `${(100 / 12) * (window.innerWidth < 600 ? 10 : 8)}%`;\r\n modalContainer.style.flexWrap = \"wrap\";\r\n modalContainer.style.justifyContent = \"space-between\";\r\n modalContainer.style.boxSizing = \"border-box\";\r\n modalContainer.style.background = \"#ffffff\";\r\n if (direction === \"rtl\") {\r\n modalContainer.style.borderRight = `5px solid ${style.borderColor}`;\r\n modalContainer.style.borderLeft = `1px solid ${style.borderColor}`;\r\n } else {\r\n modalContainer.style.borderLeft = `5px solid ${style.borderColor}`;\r\n modalContainer.style.borderRight = `1px solid ${style.borderColor}`;\r\n }\r\n modalContainer.style.borderTop = `1px solid ${style.borderColor}`;\r\n modalContainer.style.borderBottom = `1px solid ${style.borderColor}`;\r\n modalContainer.style.padding = \"1.25em 1.25em\";\r\n modalContainer.style.borderRadius = \"0.3em\";\r\n modalContainer.style.boxShadow = `1px 1px 5px ${style.borderColor}`;\r\n modalContainer.style.backgroundColor = style.containerBk;\r\n\r\n modal.appendChild(modalContainer);\r\n //#endregion\r\n ////////////////////////////////////// close icon item ///////////////////////////////////////////////////\r\n //#region\r\n const modalCloseIcon = document.createElement(\"div\");\r\n modalCloseIcon.style.position = \"absolute\";\r\n modalCloseIcon.style.top = \"-0.75em\";\r\n if (direction === \"rtl\") {\r\n modalCloseIcon.style.left = \"-0.75em\";\r\n } else {\r\n modalCloseIcon.style.right = \"-0.75em\";\r\n }\r\n modalCloseIcon.style.margin = \"0px\";\r\n modalCloseIcon.style.cursor = \"pointer\";\r\n modalCloseIcon.appendChild(closeIcon);\r\n\r\n modalCloseIcon.onmouseenter = function () {\r\n closeIcon.style.fill = style?.closeIconColor_hover;\r\n closeIcon.style.background = style?.closeIconBk_hover;\r\n };\r\n\r\n modalCloseIcon.onmouseleave = function () {\r\n closeIcon.style.fill = style?.closeIconColor;\r\n closeIcon.style.background = style?.closeIconBk;\r\n };\r\n\r\n modalContainer.appendChild(modalCloseIcon);\r\n modalCloseIcon.onclick = function (event) {\r\n while (modal?.firstChild) {\r\n modal.removeChild(modal.lastChild);\r\n }\r\n modal.remove();\r\n };\r\n //#endregion\r\n ////////////////////////////////////// header container for mobile ///////////////////////////////////////////////////\r\n //#region\r\n let modalHeaderContainer = null;\r\n\r\n if (window?.innerWidth < 600 && !style?.headerIconSameLvl_xs) {\r\n modalHeaderContainer = document.createElement(\"div\");\r\n modalHeaderContainer.style.position = \"relative\";\r\n modalHeaderContainer.style.margin = \"0px\";\r\n modalHeaderContainer.style.display = \"flex\";\r\n modalHeaderContainer.style.flexGrow = \"0\";\r\n modalHeaderContainer.style.flexBasis = `${(100 / 12) * 12}%`;\r\n modalHeaderContainer.style.width = `${(100 / 12) * 12}%`;\r\n modalHeaderContainer.style.flexWrap = \"wrap\";\r\n modalHeaderContainer.style.alignSelf = \"self-start\";\r\n modalHeaderContainer.style.alignItems = \"center\";\r\n modalHeaderContainer.style.justifyContent = \"flex-start\";\r\n\r\n modalContainer.appendChild(modalHeaderContainer);\r\n }\r\n\r\n //#endregion\r\n ////////////////////////////////////// icon header item ///////////////////////////////////////////////////\r\n //#region\r\n if (headerIcon) {\r\n const modalIcon = document.createElement(\"div\");\r\n modalIcon.style.position = \"relative\";\r\n modalIcon.style.margin = \"0px\";\r\n modalIcon.style.padding = \"0px\";\r\n modalIcon.style.display = \"flex\";\r\n modalIcon.style.flexGrow = \"0\";\r\n modalIcon.style.flexBasis = `${(100 / 12) * (window.innerWidth < 600 ? 1 : 1)}%`;\r\n modalIcon.style.width = `${(100 / 12) * (window.innerWidth < 600 ? 1 : 1)}%`;\r\n modalIcon.style.flexWrap = \"wrap\";\r\n modalIcon.style.alignSelf = \"stretch\";\r\n modalIcon.style.alignItems = \"center\";\r\n\r\n modalIcon.appendChild(headerIcon);\r\n\r\n if (window?.innerWidth < 600 && modalHeaderContainer) {\r\n modalHeaderContainer.appendChild(modalIcon);\r\n } else {\r\n modalContainer.appendChild(modalIcon);\r\n }\r\n }\r\n\r\n //#endregion\r\n\r\n ////////////////////////////////////// container text child item ///////////////////////////////////////////////////\r\n //#region\r\n const modalContainerChild = document.createElement(\"div\");\r\n modalContainerChild.style.position = \"relative\";\r\n modalContainerChild.style.margin = \"0px\";\r\n\r\n if (direction === \"rtl\") {\r\n modalContainerChild.style.paddingRight = \"6px\";\r\n } else {\r\n modalContainerChild.style.paddingLeft = \"6px\";\r\n }\r\n\r\n modalContainerChild.style.display = \"flex\";\r\n modalContainerChild.style.flexGrow = \"0\";\r\n modalContainerChild.style.flexBasis = `calc(${(100 / 12) * (window.innerWidth < 600 && !style?.headerIconSameLvl_xs? 12 : 11)}%${window.innerWidth < 600 && !style?.headerIconSameLvl_xs? \"\" : \" - 10px\"})`;\r\n modalContainerChild.style.width = `calc(${(100 / 12) * (window.innerWidth < 600 && !style?.headerIconSameLvl_xs? 12 : 11)}%${window.innerWidth < 600 && !style?.headerIconSameLvl_xs? \"\" : \" - 10px\"})`;\r\n modalContainerChild.style.flexWrap = \"wrap\";\r\n modalContainerChild.style.alignSelf = \"center\";\r\n modalContainerChild.style.alignItems = \"center\";\r\n\r\n modalContainer.appendChild(modalContainerChild);\r\n //#endregion\r\n ////////////////////////////////////// title item ///////////////////////////////////////////////////\r\n //#region\r\n const modalTitle = document.createElement(\"div\");\r\n modalTitle.style.position = \"relative\";\r\n modalTitle.style.margin = \"auto\";\r\n modalTitle.style.display = \"flex\";\r\n modalTitle.style.flexGrow = \"0\";\r\n modalTitle.style.flexBasis = `calc(${(100 / 12) * (window.innerWidth < 600 && !style?.headerIconSameLvl_xs ? 11 : 12)}%${window.innerWidth < 600 && !style?.headerIconSameLvl_xs? \" - 10px\" : \"\"})`;\r\n modalTitle.style.width = `calc(${(100 / 12) * (window.innerWidth < 600 && !style?.headerIconSameLvl_xs? 11 : 12)}%${window.innerWidth < 600 && !style?.headerIconSameLvl_xs? \" - 10px\" : \"\"})`;\r\n modalTitle.style.flexWrap = \"wrap\";\r\n modalTitle.style.alignSelf = \"center\";\r\n modalTitle.style.alignItems = \"center\";\r\n modalTitle.style.whiteSpace = \"nowrap\";\r\n modalTitle.style.fontWeight = \"bold\";\r\n modalTitle.style.fontSize = window.innerWidth < 600 ? style.fontSizeTitle_xs : style.fontSizeTitle;\r\n modalTitle.style.fontFamily = \"system-ui\";\r\n modalTitle.style.textAlign = \"start\";\r\n modalTitle.style.lineHeight = \"1.5em\";\r\n modalTitle.style.color = style.titleColor;\r\n modalTitle.innerHTML = style.title;\r\n if (window?.innerWidth < 600 && modalHeaderContainer) {\r\n modalHeaderContainer.appendChild(modalTitle);\r\n } else {\r\n modalContainerChild.appendChild(modalTitle);\r\n }\r\n\r\n //#endregion\r\n ////////////////////////////////////// text item ///////////////////////////////////////////////////\r\n //#region\r\n const modalText = document.createElement(\"div\");\r\n modalText.style.position = \"relative\";\r\n modalText.style.margin = \"auto\";\r\n modalText.style.display = \"flex\";\r\n modalText.style.flexGrow = \"0\";\r\n modalText.style.flexBasis = `${(100 / 12) * 12}%`;\r\n modalText.style.width = `${(100 / 12) * 12}%`;\r\n modalText.style.flexWrap = \"wrap\";\r\n modalText.style.alignSelf = \"flex-start\";\r\n modalText.style.alignItems = \"flex-start\";\r\n modalText.style.whiteSpace = \"pre-line\";\r\n modalText.style.overflow = \"auto\";\r\n modalText.style.maxHeight = `calc(100vh - 2.5em - 6em - 2em)`;\r\n modalText.style.fontSize = window.innerWidth < 600 ? style.fontSize_xs : style.fontSize;\r\n modalText.style.fontFamily = \"system-ui\";\r\n modalText.style.textAlign = style.textAlign;\r\n modalText.style.color = style.textColor;\r\n modalText.innerHTML = strText;\r\n\r\n modalContainerChild.appendChild(modalText);\r\n //#endregion\r\n ////////////////////////////////////// add to body /////////////////////////////////////////////\r\n //#region\r\n document.body.appendChild(modal);\r\n\r\n modal.onclick = function (event) {\r\n if (event?.target === modal) {\r\n while (event?.target?.firstChild) {\r\n event.target.removeChild(event.target.lastChild);\r\n }\r\n event.target.remove();\r\n }\r\n };\r\n\r\n return {\r\n eventClose: () => {\r\n while (modal?.firstChild) {\r\n modal.removeChild(modal.lastChild);\r\n }\r\n modal.remove();\r\n },\r\n };\r\n //#endregion\r\n } catch (error) {\r\n //console.log(error)\r\n }\r\n};\r\n","export const viewConfirmation = (\n strText,\n action = null,\n label = null,\n direction,\n style = {\n title: null,\n containerBk: null,\n borderColor: null,\n iconColorFill: null,\n iconWidth: null,\n titleColor: null,\n textColor: null,\n textAlign: null,\n fontSizeTitle: null,\n fontSizeTitle_xs: null,\n fontSize: null,\n fontSize_xs: null,\n iconEle: null,\n yesBtnColor: null,\n yesBtnBk: null,\n noBtnColor: null,\n btnFontSize: null,\n btnFontSize_xs: null,\n }\n) => {\n try {\n if (typeof window === \"undefined\" || typeof document === \"undefined\") {\n return;\n }\n //////////////////////////////////////////// constant (FOR INTERNAL COMPARE ) ///////////////////////////////////////////////////\n //#region\n const xmlns = \"http://www.w3.org/2000/svg\";\n //#endregion\n //////////////////////////////////////////// init style ///////////////////////////////////////////////////\n //#region\n\n //info #047dbc #04a8f9 #efeefe #5458f7\n //error #d60000 #880300 #feeeef #eb5756\n //warning #fec107 #bc910e #fef8e8 #f2c94d\n //success #4cb050 #3a833c #e5faf5 #00cc99\n if (!style) {\n style = {};\n }\n if (!style?.title) {\n style.title = direction === \"rtl\" ? \"تأكيد\" : \"Confirmation\";\n }\n if (!label) {\n label = {};\n }\n if (!label?.yes) {\n label.yes = direction === \"rtl\" ? \"موافق\" : \"Agree\";\n }\n if (!label?.no) {\n label.no = direction === \"rtl\" ? \"إلغاء\" : \"Cancel\";\n }\n if (!style?.containerBk) {\n style.containerBk = \"#ffffff\";\n }\n if (!style?.borderColor) {\n style.borderColor = \"#ffc800\";\n }\n if (!style?.iconColorFill) {\n style.iconColorFill = \"#ffc800\";\n }\n if (!style?.iconWidth) {\n style.iconWidth = \"100%\";\n }\n if (!style?.titleColor) {\n style.titleColor = \"#ecc243\";\n }\n if (!style?.textColor) {\n style.textColor = \"#55585c\";\n }\n if (!style?.textAlign) {\n style.textAlign = \"justify\";\n }\n if (!style?.fontSizeTitle_xs) {\n style.fontSizeTitle_xs = style?.fontSizeTitle ? style?.fontSizeTitle : \"24px\";\n }\n if (!style?.fontSizeTitle) {\n style.fontSizeTitle = \"24px\";\n }\n if (!style?.fontSize_xs) {\n style.fontSize_xs = style?.fontSize ? style?.fontSize : \"13px\";\n }\n if (!style?.fontSize) {\n style.fontSize = \"16px\";\n }\n if (!style?.yesBtnColor) {\n style.yesBtnColor = \"#ffffff\";\n }\n if (!style?.yesBtnBk) {\n style.yesBtnBk = \"#1769aa\";\n }\n if (!style?.noBtnColor) {\n style.noBtnColor = \"#1769aa\";\n }\n if (!style?.btnFontSize) {\n style.btnFontSize = \"16px\";\n }\n if (!style?.btnFontSize_xs) {\n style.btnFontSize_xs = \"12px\";\n }\n //#endregion\n //////////////////////////////////////////// create header icon ///////////////////////////////////////////////////\n //#region\n let headerIcon = document.createElementNS(xmlns, \"svg\");\n headerIcon.setAttributeNS(null, \"viewBox\", \"5 5 54 54\");\n\n if (!style?.iconEle) {\n const path1 = document.createElementNS(xmlns, \"path\");\n path1.setAttributeNS(null, \"d\", \"M0 0h24v24H0z\");\n path1.setAttributeNS(null, \"fill\", \"none\");\n headerIcon.appendChild(path1);\n\n const path2 = document.createElementNS(xmlns, \"path\");\n path2.setAttributeNS(\n null,\n \"d\",\n \"M50.38,31.45,32.55,13.62a.77.77,0,0,0-1.1,0L13.62,31.45a.78.78,0,0,0,0,1.1L31.45,50.38a.77.77,0,0,0,1.1,0L50.38,32.55A.78.78,0,0,0,50.38,31.45ZM32,43a2,2,0,1,1,2-2A2,2,0,0,1,32,43Zm2-7H30L29,22h6Z\"\n );\n headerIcon.appendChild(path2);\n\n const path3 = document.createElementNS(xmlns, \"path\");\n path3.setAttributeNS(\n null,\n \"d\",\n \"M53.91,27.91,36.09,10.09a5.78,5.78,0,0,0-8.18,0L10.09,27.91a5.78,5.78,0,0,0,0,8.18L27.91,53.91a5.78,5.78,0,0,0,8.18,0L53.91,36.09A5.78,5.78,0,0,0,53.91,27.91ZM51.79,34,34,51.79a2.75,2.75,0,0,1-3.92,0L12.21,34a2.76,2.76,0,0,1,0-3.92L30,12.21a2.75,2.75,0,0,1,3.92,0L51.79,30A2.76,2.76,0,0,1,51.79,34Z\"\n );\n headerIcon.appendChild(path3);\n\n headerIcon.style.fill = style.iconColorFill;\n headerIcon.style.width = style.iconWidth;\n if (window.innerWidth >= 600) {\n headerIcon.style.paddingLeft = \"10px\";\n headerIcon.style.paddingRight = \"10px\";\n }\n } else {\n headerIcon = style?.iconEle;\n }\n //#endregion\n //////////////////////////////////////// root of modal //////////////////////////////////////////////\n //#region\n const modal = document.createElement(\"div\");\n\n modal.style.position = \"fixed\";\n modal.style.left = \"0px\";\n modal.style.top = \"0px\";\n modal.style.bottom = \"0px\";\n modal.style.right = \"0px\";\n modal.style.width = \"100%\";\n modal.style.height = \"100%\";\n modal.style.margin = \"0px\";\n modal.style.padding = \"0px\";\n modal.style.backgroundColor = \"rgba(0, 0, 0, 0.5)\";\n modal.style.opacity = \"1\";\n modal.style.transform = \"scale(1)\";\n modal.style.transition = \"visibility 0s linear 0.25s, opacity 0.25s 0s, transform 0.25s\";\n modal.style.display = \"flex\";\n modal.style.flexDirection = \"row\";\n modal.style.justifyContent = \"center\";\n modal.style.alignSelf = \"center\";\n modal.style.alignItems = \"center\";\n modal.style.alignContent = \"center\";\n modal.style.flexWrap = \"wrap\";\n modal.style.boxSizing = \"border-box\";\n modal.style.zIndex = 1301;\n modal.style.direction = direction === \"rtl\" ? direction : \"ltr\";\n //#endregion\n ////////////////////////////////////// container ///////////////////////////////////////////////////\n //#region\n const modalContainer = document.createElement(\"div\");\n modalContainer.animate(\n [\n {\n transform: \"scale(0)\",\n opacity: \"0\",\n },\n {\n transform: \"scale(1)\",\n opacity: \"1\",\n },\n ],\n {\n duration: 200,\n iterations: 1,\n }\n );\n modalContainer.style.position = \"relative\";\n modalContainer.style.margin = \"0px\";\n modalContainer.style.display = \"flex\";\n modalContainer.style.flexGrow = \"0\";\n modalContainer.style.flexBasis = `${(100 / 12) * (window.innerWidth < 600 ? 11 : 8)}%`;\n modalContainer.style.width = `${(100 / 12) * (window.innerWidth < 600 ? 11 : 8)}%`;\n modalContainer.style.flexWrap = \"wrap\";\n modalContainer.style.justifyContent = \"space-between\";\n modalContainer.style.boxSizing = \"border-box\";\n modalContainer.style.background = \"#ffffff\";\n modalContainer.style.borderTop = `8px solid ${style.borderColor}`;\n modalContainer.style.padding = \"1.25em 1.25em\";\n modalContainer.style.borderRadius = \"0.3em\";\n modalContainer.style.boxShadow = `1px 1px 5px #d9d9d9`;\n modalContainer.style.backgroundColor = style.containerBk;\n\n modal.appendChild(modalContainer);\n //#endregion\n ////////////////////////////////////// container header icon and title for mobile ///////////////////////////////////////////////////\n //#region\n let modalContainerHeaderMobile = null;\n if (window.innerWidth < 600) {\n modalContainerHeaderMobile = document.createElement(\"div\");\n modalContainerHeaderMobile.style.position = \"relative\";\n modalContainerHeaderMobile.style.margin = \"0px\";\n modalContainerHeaderMobile.style.display = \"flex\";\n modalContainerHeaderMobile.style.flexGrow = \"0\";\n modalContainerHeaderMobile.style.flexBasis = `calc(${(100 / 12) * 12})`;\n modalContainerHeaderMobile.style.width = `calc(${(100 / 12) * 12})`;\n modalContainerHeaderMobile.style.flexWrap = \"wrap\";\n modalContainerHeaderMobile.style.alignSelf = \"center\";\n modalContainerHeaderMobile.style.alignItems = \"center\";\n modalContainerHeaderMobile.style.justifyContent = \"flex-start\";\n\n modalContainer.appendChild(modalContainerHeaderMobile);\n }\n //#endregion\n ////////////////////////////////////// icon header item ///////////////////////////////////////////////////\n //#region\n const modalIcon = document.createElement(\"div\");\n modalIcon.style.position = \"relative\";\n modalIcon.style.margin = \"0px\";\n modalIcon.style.padding = \"0px\";\n modalIcon.style.display = \"flex\";\n modalIcon.style.flexGrow = \"0\";\n modalIcon.style.flexBasis = `${(100 / 12) * (window.innerWidth < 600 ? 3 : 2)}%`;\n modalIcon.style.width = `${(100 / 12) * (window.innerWidth < 600 ? 3 : 2)}%`;\n modalIcon.style.flexWrap = \"wrap\";\n modalIcon.style.alignSelf = \"stretch\";\n modalIcon.style.alignItems = \"center\";\n modalIcon.style.justifyContent = \"flex-start\";\n modalIcon.appendChild(headerIcon);\n\n if (window.innerWidth < 600 && modalContainerHeaderMobile) {\n modalContainerHeaderMobile.appendChild(modalIcon);\n } else {\n modalContainer.appendChild(modalIcon);\n }\n //#endregion\n ////////////////////////////////////// container child item ///////////////////////////////////////////////////\n //#region\n const modalContainerChild = document.createElement(\"div\");\n modalContainerChild.style.position = \"relative\";\n modalContainerChild.style.margin = \"0px\";\n if (direction === \"rtl\") {\n modalContainerChild.style.paddingRight = \"6px\";\n } else {\n modalContainerChild.style.paddingLeft = \"6px\";\n }\n modalContainerChild.style.display = \"flex\";\n modalContainerChild.style.flexGrow = \"0\";\n modalContainerChild.style.flexBasis = `calc(${(100 / 12) * (window.innerWidth < 600 ? 12 : 10)}%${window.innerWidth < 600 ? \"\" : \" - 6px\"})`;\n modalContainerChild.style.width = `calc(${(100 / 12) * (window.innerWidth < 600 ? 12 : 10)}%${window.innerWidth < 600 ? \"\" : \" - 6px\"})`;\n modalContainerChild.style.flexWrap = \"wrap\";\n modalContainerChild.style.alignSelf = \"center\";\n modalContainerChild.style.alignItems = \"center\";\n\n modalContainer.appendChild(modalContainerChild);\n //#endregion\n ////////////////////////////////////// title item ///////////////////////////////////////////////////\n //#region\n const modalTitle = document.createElement(\"div\");\n modalTitle.style.position = \"relative\";\n modalTitle.style.margin = \"auto\";\n modalTitle.style.display = \"flex\";\n modalTitle.style.flexGrow = \"0\";\n modalTitle.style.flexBasis = `calc(${(100 / 12) * (window.innerWidth < 600 ? 9 : 12)}%${window.innerWidth < 600 ? \" - 10px\" : \"\"})`;\n modalTitle.style.width = `calc(${(100 / 12) * (window.innerWidth < 600 ? 9 : 12)}%${window.innerWidth < 600 ? \" - 10px\" : \"\"})`;\n modalTitle.style.flexWrap = \"wrap\";\n modalTitle.style.alignSelf = \"flex-start\";\n modalTitle.style.alignItems = \"center\";\n modalTitle.style.whiteSpace = \"nowrap\";\n modalTitle.style.fontWeight = \"bold\";\n modalTitle.style.fontSize = window.innerWidth < 600 ? style.fontSizeTitle_xs : style.fontSizeTitle;\n modalTitle.style.fontFamily = \"system-ui\";\n modalTitle.style.textAlign = \"start\";\n modalTitle.style.lineHeight = \"1.5em\";\n modalTitle.style.color = style.titleColor;\n modalTitle.innerHTML = style.title;\n\n if (window.innerWidth < 600 && modalContainerHeaderMobile) {\n modalContainerHeaderMobile.appendChild(modalTitle);\n } else {\n modalContainerChild.appendChild(modalTitle);\n }\n\n //#endregion\n ////////////////////////////////////// text item ///////////////////////////////////////////////////\n //#region\n const modalText = document.createElement(\"div\");\n modalText.style.position = \"relative\";\n modalText.style.margin = \"auto\";\n modalText.style.display = \"flex\";\n modalText.style.flexGrow = \"0\";\n modalText.style.flexBasis = `${(100 / 12) * 12}%`;\n modalText.style.width = `${(100 / 12) * 12}%`;\n modalText.style.flexWrap = \"wrap\";\n modalText.style.alignSelf = \"flex-start\";\n modalText.style.alignItems = \"flex-start\";\n modalText.style.whiteSpace = \"pre-line\";\n modalText.style.overflow = \"auto\";\n modalText.style.maxHeight = `calc(100vh - 2.5em - 10em${window.innerWidth < 600 ? \" - 7em\" : \"\"})`;\n modalText.style.fontSize = window.innerWidth < 600 ? style.fontSize_xs : style.fontSize;\n modalText.style.fontFamily = \"system-ui\";\n modalText.style.textAlign = style.textAlign;\n modalText.style.color = style.textColor;\n modalText.innerHTML = strText;\n\n modalContainerChild.appendChild(modalText);\n //#endregion\n ////////////////////////////////////// container action item ///////////////////////////////////////////////////\n //#region\n let lineSeparator = document.createElement(\"hr\");\n lineSeparator.style.width = \"100%\";\n lineSeparator.style.border = \"0\";\n lineSeparator.style.margin = \"0.5em 0\";\n lineSeparator.style.height = \"1px\";\n lineSeparator.style.background = \"#c2c2c2\";\n modalContainer.appendChild(lineSeparator);\n\n const modalContainerAction = document.createElement(\"div\");\n modalContainerAction.style.position = \"relative\";\n modalContainerAction.style.margin = \"0px\";\n modalContainerAction.style.display = \"flex\";\n modalContainerAction.style.flexGrow = \"0\";\n modalContainerAction.style.flexBasis = `${(100 / 12) * 12}%`;\n modalContainerAction.style.width = `${(100 / 12) * 12}%`;\n modalContainerAction.style.flexWrap = \"nowrap\";\n modalContainerAction.style.alignSelf = \"center\";\n modalContainerAction.style.alignItems = \"center\";\n modalContainerAction.style.justifyContent = \"flex-end\";\n modalContainerAction.style.marginTop = \"0.5em\";\n\n modalContainer.appendChild(modalContainerAction);\n //#endregion\n ////////////////////////////////////// action no button item ///////////////////////////////////////////////////\n //#region\n const noBtnContainer = document.createElement(\"div\");\n noBtnContainer.style.position = \"relative\";\n noBtnContainer.style.margin = \"0px\";\n noBtnContainer.style.display = \"flex\";\n noBtnContainer.style.flexGrow = \"0\";\n noBtnContainer.style.flexBasis = `auto`;\n noBtnContainer.style.width = `auto`;\n noBtnContainer.style.flexWrap = \"wrap\";\n noBtnContainer.style.justifyContent = \"flex-end\";\n\n modalContainerAction.appendChild(noBtnContainer);\n\n const noBtn = document.createElement(\"button\");\n noBtn.style.borderRadius = \"0.5rem\";\n noBtn.style.padding = window.innerWidth < 600 ? \"0.35rem\" : \"0.5rem\";\n noBtn.style.lineHeight = window.innerWidth < 600 ? \"1.35rem\" : \"1.5rem\";\n noBtn.style.margin = \"auto 0.65rem\";\n noBtn.style.minHeight = \"2rem\";\n noBtn.style.minWidth = \"3.25rem\";\n noBtn.style.outline = \"none\";\n noBtn.style.boxSizing = \"border-box\";\n noBtn.style.border = `0.13rem solid ${style?.noBtnColor}`;\n noBtn.style.background = \"#ffffff\";\n noBtn.style.color = style?.noBtnColor;\n noBtn.style.fontSize = window?.innerWidth < 600 ? style?.btnFontSize_xs : style?.btnFontSize;\n noBtn.style.fontFamily =\"system-ui\";\n noBtn.style.cursor = \"pointer\";\n noBtn.style.transition = \"all 0.5s ease 0s\";\n noBtn.onmouseenter = function () {\n noBtn.style.border = `0.13rem solid ${style?.noBtnColor + \"b1\"}`;\n noBtn.style.color = style?.noBtnColor + \"b1\";\n\n noBtn.style.background = \"#fafafa\";\n noBtn.style.boxShadow = \"rgba(0, 0, 0, 0.19) 0px 10px 20px, rgba(0, 0, 0, 0.23) 0px 6px 6px\";\n };\n\n noBtn.onmouseleave = function () {\n noBtn.style.border = `0.13rem solid ${style?.noBtnColor}`;\n noBtn.style.color = style?.noBtnColor;\n\n noBtn.style.background = \"#ffffff\";\n noBtn.style.boxShadow = \"none\";\n };\n\n noBtn.innerHTML = label.no;\n noBtnContainer.appendChild(noBtn);\n\n noBtn.onclick = function (event) {\n if (action?.no && typeof action?.no === \"function\") {\n action?.no(event);\n }\n while (modal?.firstChild) {\n modal.removeChild(modal.lastChild);\n }\n modal.remove();\n };\n\n //#endregion\n ////////////////////////////////////// action yes button item ///////////////////////////////////////////////////\n //#region\n const yesBtnContainer = document.createElement(\"div\");\n yesBtnContainer.style.position = \"relative\";\n yesBtnContainer.style.margin = \"0px\";\n yesBtnContainer.style.display = \"flex\";\n yesBtnContainer.style.flexGrow = \"0\";\n yesBtnContainer.style.flexBasis = `auto`;\n yesBtnContainer.style.width = `auto`;\n yesBtnContainer.style.flexWrap = \"wrap\";\n yesBtnContainer.style.justifyContent = \"flex-end\";\n\n modalContainerAction.appendChild(yesBtnContainer);\n\n const yesBtn = document.createElement(\"button\");\n yesBtn.style.borderRadius = \"0.5rem\";\n yesBtn.style.padding = window.innerWidth < 600 ? \"0.35rem\" : \"0.5rem\";\n yesBtn.style.lineHeight = window.innerWidth < 600 ? \"1.35rem\" : \"1.5rem\";\n yesBtn.style.margin = \"auto 0.65rem\";\n yesBtn.style.minHeight = \"2rem\";\n yesBtn.style.minWidth = \"3.25rem\";\n yesBtn.style.outline = \"none\";\n yesBtn.style.boxSizing = \"border-box\";\n yesBtn.style.border = \"0.166667rem solid transparent\";\n yesBtn.style.background = style?.yesBtnBk;\n yesBtn.style.color = style?.yesBtnColor;\n yesBtn.style.fontSize = window?.innerWidth < 600 ? style?.btnFontSize_xs : style?.btnFontSize;\n yesBtn.style.fontFamily = \"system-ui\";\n yesBtn.style.cursor = \"pointer\";\n yesBtn.style.transition = \"all 0.5s ease 0s\";\n yesBtn.onmouseenter = function () {\n yesBtn.style.background = style?.yesBtnBk + \"e1\";\n yesBtn.style.boxShadow = \"rgba(0, 0, 0, 0.19) 0px 10px 20px, rgba(0, 0, 0, 0.23) 0px 6px 6px\";\n };\n\n yesBtn.onmouseleave = function () {\n yesBtn.style.background = style?.yesBtnBk;\n yesBtn.style.boxShadow = \"none\";\n };\n\n yesBtn.innerHTML = label.yes;\n yesBtnContainer.appendChild(yesBtn);\n\n yesBtn.onclick = function (event) {\n if (action?.yes && typeof action?.yes === \"function\") {\n action?.yes(event);\n } else if (action && typeof action === \"function\") {\n action(event);\n }\n\n while (modal?.firstChild) {\n modal.removeChild(modal.lastChild);\n }\n modal.remove();\n };\n\n //#endregion\n ////////////////////////////////////// add to body /////////////////////////////////////////////\n //#region\n document.body.appendChild(modal);\n\n return {\n eventClose: () => {\n while (modal?.firstChild) {\n modal.removeChild(modal.lastChild);\n }\n modal.remove();\n },\n };\n //#endregion\n } catch (error) {\n // console.log(error);\n }\n};"," const viewInlineTextDialog = (\r\n strText,\r\n direction,\r\n style = { iconColorBk: null, iconColorFill: null, borderColor: null, textColor: null, textAlign: null, fontSize: null, fontSize_xs: null }\r\n ) => {\r\n try {\r\n if (typeof window === \"undefined\" || typeof document === \"undefined\") {\r\n return;\r\n }\r\n //////////////////////////////////////////// init style ///////////////////////////////////////////////////\r\n //#region\r\n if (!style) {\r\n }\r\n if (!style?.borderColor) {\r\n style.borderColor = \"#5458f7\";\r\n }\r\n if (!style?.iconColorBk) {\r\n style.iconColorBk = \"#ddd\";\r\n }\r\n if (!style?.iconColorFill) {\r\n style.iconColorFill = \"#cd3a37\";\r\n }\r\n if (!style?.textColor) {\r\n style.textColor = \"#55585c\";\r\n }\r\n if (!style?.textAlign) {\r\n style.textAlign = \"justify\";\r\n }\r\n if (!style?.fontSize_xs) {\r\n style.fontSize_xs = style?.fontSize ? style?.fontSize : \"13px\";\r\n }\r\n if (!style?.fontSize) {\r\n style.fontSize = \"16px\";\r\n }\r\n //#endregion\r\n //////////////////////////////////////////// create icon ///////////////////////////////////////////////////\r\n //#region\r\n const xmlns = \"http://www.w3.org/2000/svg\";\r\n const closeIcon = document.createElementNS(xmlns, \"svg\");\r\n closeIcon.setAttributeNS(null, \"viewBox\", \"0 0 24 24\");\r\n const path1 = document.createElementNS(xmlns, \"path\");\r\n path1.setAttributeNS(null, \"d\", \"M0 0h24v24H0z\");\r\n path1.setAttributeNS(null, \"fill\", \"none\");\r\n const path2 = document.createElementNS(xmlns, \"path\");\r\n path2.setAttributeNS(null, \"d\", \"M19 6.41L17.59 5 12 10.59 6.41 5 5 6.41 10.59 12 5 17.59 6.41 19 12 13.41 17.59 19 19 17.59 13.41 12z\");\r\n closeIcon.appendChild(path1);\r\n closeIcon.appendChild(path2);\r\n closeIcon.style.cursor = \"pointer\";\r\n closeIcon.style.fill = style.iconColorFill;\r\n closeIcon.style.width = \"1.5rem\";\r\n closeIcon.style.borderRadius = `50%`;\r\n closeIcon.style.background = style.iconColorBk;\r\n //#endregion\r\n //////////////////////////////////////// root of modal //////////////////////////////////////////////\r\n //#region\r\n const modal = document.createElement(\"div\");\r\n \r\n modal.style.position = \"fixed\";\r\n modal.style.left = \"0px\";\r\n modal.style.top = \"0px\";\r\n modal.style.bottom = \"0px\";\r\n modal.style.right = \"0px\";\r\n modal.style.width = \"100%\";\r\n modal.style.height = \"100%\";\r\n modal.style.margin = \"0px\";\r\n modal.style.padding = \"0px\";\r\n modal.style.backgroundColor = \"rgba(0, 0, 0, 0.5)\";\r\n modal.style.opacity = \"1\";\r\n modal.style.transform = \"scale(1)\";\r\n modal.style.transition = \"visibility 0s linear 0.25s, opacity 0.25s 0s, transform 0.25s\";\r\n modal.style.display = \"flex\";\r\n modal.style.flexDirection = \"row\";\r\n modal.style.justifyContent = \"center\";\r\n modal.style.alignSelf = \"center\";\r\n modal.style.alignItems = \"center\";\r\n modal.style.alignContent = \"center\";\r\n modal.style.flexWrap = \"wrap\";\r\n modal.style.boxSizing = \"border-box\";\r\n modal.style.zIndex = 1301;\r\n modal.style.direction = direction === \"rtl\" ? direction : \"ltr\";\r\n //#endregion\r\n ////////////////////////////////////// container ///////////////////////////////////////////////////\r\n //#region\r\n const modalContainer = document.createElement(\"div\");\r\n modalContainer.animate(\r\n [\r\n {\r\n transform: \"scale(0)\",\r\n opacity: \"0\",\r\n },\r\n {\r\n transform: \"scale(1)\",\r\n opacity: \"1\",\r\n },\r\n ],\r\n {\r\n duration: 200,\r\n iterations: 1,\r\n }\r\n );\r\n modalContainer.style.position = \"relative\";\r\n modalContainer.style.margin = \"0px\";\r\n modalContainer.style.display = \"flex\";\r\n modalContainer.style.flexGrow = \"0\";\r\n modalContainer.style.flexBasis = `${(100 / 12) * (window.innerWidth < 600 ? 11 : 10)}%`;\r\n modalContainer.style.width = `${(100 / 12) * (window.innerWidth < 600 ? 11 : 10)}%`;\r\n modalContainer.style.flexWrap = \"wrap\";\r\n modalContainer.style.justifyContent = \"space-between\";\r\n modalContainer.style.boxSizing = \"border-box\";\r\n modalContainer.style.background = \"#ffffff\";\r\n modalContainer.style.border = `1px solid ${style.borderColor}`;\r\n modalContainer.style.padding = \"1.25em 1.25em\";\r\n modalContainer.style.borderRadius = \"0.3em\";\r\n modalContainer.style.boxShadow = `1px 1px 5px ${style.borderColor + \"a1\"}`;\r\n \r\n modal.appendChild(modalContainer);\r\n \r\n //#endregion\r\n ////////////////////////////////////// close icon item ///////////////////////////////////////////////////\r\n //#region\r\n const modalIcon = document.createElement(\"div\");\r\n modalIcon.style.position = \"absolute\";\r\n modalIcon.style.top = \"-0.75em\";\r\n if (direction === \"rtl\") {\r\n modalIcon.style.left = \"-0.75em\";\r\n } else {\r\n modalIcon.style.right = \"-0.75em\";\r\n }\r\n modalIcon.style.margin = \"0px\";\r\n modalIcon.style.cursor = \"pointer\";\r\n modalIcon.appendChild(closeIcon);\r\n \r\n modalIcon.onmouseenter = function () {\r\n closeIcon.style.fill = style.iconColorBk;\r\n closeIcon.style.background = style.iconColorFill;\r\n };\r\n \r\n modalIcon.onmouseleave = function () {\r\n closeIcon.style.fill = style.iconColorFill;\r\n closeIcon.style.background = style.iconColorBk;\r\n };\r\n \r\n modalContainer.appendChild(modalIcon);\r\n modalIcon.onclick = function (event) {\r\n while (modal?.firstChild) {\r\n modal.removeChild(modal.lastChild);\r\n }\r\n modal.remove();\r\n };\r\n //#endregion\r\n ////////////////////////////////////// text item ///////////////////////////////////////////////////\r\n //#region\r\n const modalDetail = document.createElement(\"div\");\r\n modalDetail.style.position = \"relative\";\r\n modalDetail.style.margin = \"0px\";\r\n modalDetail.style.display = \"flex\";\r\n modalDetail.style.flexGrow = \"0\";\r\n modalDetail.style.flexBasis = `${(100 / 12) * 12}%`;\r\n modalDetail.style.width = `${(100 / 12) * 12}%`;\r\n modalDetail.style.flexWrap = \"wrap\";\r\n modalDetail.style.alignSelf = \"flex-start\";\r\n modalDetail.style.alignItems = \"flex-start\";\r\n modalDetail.style.whiteSpace = \"pre-line\";\r\n modalDetail.style.overflow = \"auto\";\r\n modalDetail.style.maxHeight = \"calc(100vh - 2.5em - 3em)\";\r\n modalDetail.style.fontSize = window.innerWidth < 600 ? style.fontSize_xs : style.fontSize;\r\n modalDetail.style.textAlign = style.textAlign;\r\n modalDetail.style.color = style.textColor;\r\n modalDetail.innerHTML = strText;\r\n \r\n modalContainer.appendChild(modalDetail);\r\n //#endregion\r\n ////////////////////////////////////// add to body /////////////////////////////////////////////\r\n //#region\r\n document.body.appendChild(modal);\r\n \r\n modal.onclick = function (event) {\r\n if (event?.target === modal) {\r\n while (event?.target?.firstChild) {\r\n event.target.removeChild(event.target.lastChild);\r\n }\r\n event.target.remove();\r\n }\r\n };\r\n \r\n return {\r\n eventClose: () => {\r\n while (modal?.firstChild) {\r\n modal.removeChild(modal.lastChild);\r\n }\r\n modal.remove();\r\n },\r\n };\r\n //#endregion\r\n } catch (error) {\r\n //console.log(error)\r\n }\r\n };\r\n export default viewInlineTextDialog","import React, { forwardRef, useContext } from \"react\";\r\nimport { ContextThemeProvider, styleFunction } from \"@cbmisorg/styles\";\r\nimport NoteStyle from \"./NoteStyle\";\r\nimport ErrorBoundary from \"../../_helper/errorHandeling/ErrorBoundary/ErrorBoundary\";\r\nimport { Icon } from \"@cbmisorg/icons\";\r\n\r\nconst iconName={info: \"info\", warning: \"warning\", error:\"error\", success: \"checkcircle\", primary:\"Campaign\" }\r\nconst Note = forwardRef((/**@mode {any}*/props, ref) => {\r\n const theTheme = useContext(ContextThemeProvider);\r\n const {classesName, style, styleSx} = NoteStyle(theTheme);\r\n const { mode =\"primary\" ,sx = null, hidden=false, disabled=false, dir=null, className=null, id=null, ...rest } = props;\r\n const classes = style();\r\n const classesSx = styleSx({ sx , mode});\r\n const itemClasses = styleFunction.getClassName(classes?.[classesName?.note], classesSx?.[classesName?.sx], styleFunction.CheckDirectionItem(dir),styleFunction.CheckDisabledItem(disabled), styleFunction.CheckHiddenItem(hidden),styleFunction.checkExistsMargin(rest),styleFunction.checkExistsPadding(rest), className);\r\n\r\n\r\n return (\r\n \r\n
\r\n \r\n
\r\n
\r\n {props.children} \r\n
\r\n
\r\n );\r\n});\r\n\r\nexport default Note;\r\n","import { StyleBuilder, styleVariables, cssKeys, mainTheme, styleFunction } from \"@cbmisorg/styles\";\r\n\r\nexport default (objThemeInfo) => {\r\n const cssObject = objThemeInfo?.cssObject || mainTheme?.cssObject;\r\n\r\n const classesName = {\r\n note: `${styleVariables?.prefixDefaultClassName}_note`,\r\n note_icon: `${styleVariables?.prefixDefaultClassName}_note_icon`,\r\n note_content: `${styleVariables?.prefixDefaultClassName}_note_content`,\r\n\r\n sx: `${styleVariables?.prefixDefaultClassName}_note_sx`,\r\n };\r\n\r\n const style = StyleBuilder({\r\n blnRandomPrefix: false,\r\n blnIsDefaultStyle: true,\r\n blnCbmisStyle: true,\r\n objStyles: {\r\n [classesName?.note]: {\r\n display: \"flex\",\r\n position: \"relative\",\r\n width: cssObject?.size?.[cssKeys?.full],\r\n maxWidth: cssObject?.size?.[cssKeys?.full],\r\n textAlign: \"start\",\r\n justifyContent:\"flex-start\",\r\n alignItems:\"center\",\r\n },\r\n [classesName?.note_icon]: {\r\n display: \"inline-block\",\r\n position: \"relative\",\r\n fontSize: cssObject?.text?.size?.[cssKeys?.h6],\r\n width: \"max-content\",\r\n margin:0,\r\n\r\n },\r\n [classesName?.note_content]: {\r\n display: \"inline-block\",\r\n position: \"relative\",\r\n width: \"max-content\",\r\n maxWidth: \"90%\",\r\n fontSize: cssObject?.text?.size?.[cssKeys?.body2],\r\n color: styleFunction.checkColorReturnValue(cssObject?.color?.bodyColor),\r\n paddingInline: cssObject?.spacing?.[cssKeys?.sm],\r\n margin:0,\r\n\r\n\r\n },\r\n },\r\n });\r\n\r\n const styleSx = StyleBuilder({\r\n blnRandomPrefix: true,\r\n blnIsDefaultStyle: false,\r\n blnCbmisStyle: true,\r\n objStyles: {\r\n [classesName?.sx]: (props) => {\r\n return {\r\n fontSize: cssObject?.text?.size?.body2,\r\n padding: cssObject?.spacing?.[cssKeys?.sm],\r\n margin: `${cssObject?.spacing?.[cssKeys?.sm]} auto`,\r\n borderRadius: cssObject?.border?.[cssKeys?.rounded]?.md,\r\n color: styleFunction.checkColorReturnValue(props?.mode || cssObject?.color?.bodyColor),\r\n border: `${cssObject?.size?.[cssKeys?.px]} ${cssObject?.border?.[cssKeys?.border]?.dashed} ${styleFunction.checkColorReturnValue(props?.mode|| cssObject?.color?.bodyColor)}`,\r\n background: cssObject?.color?.[cssKeys?.transparent],\r\n ...props?.sx,\r\n };\r\n },\r\n },\r\n });\r\n\r\n return {\r\n classesName,\r\n style,\r\n styleSx,\r\n };\r\n};\r\n","import React, { forwardRef, useContext, useState } from 'react'\r\nimport { styleFunction, ContextThemeProvider } from '@cbmisorg/styles';\r\nimport ButtonStyle from './ButtonStyle';\r\nimport { Icon } from '@cbmisorg/icons';\r\n\r\nconst Button = forwardRef((/**@type {any}*/props, ref) => {\r\n const theTheme = useContext(ContextThemeProvider);\r\n const {classesName, style, styleSx, btnIconSize} = ButtonStyle(theTheme);\r\n const {label, color, size, icon, iconSize, endIcon, iconColor, mode, sx, hidden, disabled, dir, className, id, ...rest}= props\r\n const classes = style();\r\n const classesSx = styleSx({sx, color, size, icon, mode});\r\n const itemClasses = styleFunction.getClassName(classes?.[classesName?.button], classesSx?.[classesName?.sx], styleFunction.CheckDirectionItem(dir),styleFunction.CheckDisabledItem(disabled), styleFunction.CheckHiddenItem(hidden),styleFunction.checkExistsMargin(rest),styleFunction.checkExistsPadding(rest), className);\r\n\r\n\r\n return (\r\n \r\n {\r\n icon && (\r\n \r\n \r\n \r\n )\r\n }\r\n {\r\n label && ({label} )\r\n }\r\n {\r\n endIcon && (\r\n \r\n \r\n \r\n )\r\n }\r\n \r\n )\r\n})\r\n\r\nexport default Button","import { StyleBuilder, styleVariables, cssKeys, mainTheme, styleFunction } from \"@cbmisorg/styles\";\r\n\r\nexport default (objThemeInfo) => {\r\n const cssObject = objThemeInfo?.cssObject || mainTheme?.cssObject;\r\n\r\n const classesName = {\r\n button_container: `${styleVariables?.prefixDefaultClassName}_button_container`,\r\n button: `${styleVariables?.prefixDefaultClassName}_button`,\r\n btn_icon: `${styleVariables?.prefixDefaultClassName}_btn_icon`,\r\n btn_label: `${styleVariables?.prefixDefaultClassName}_btn_label`,\r\n sxContainer: `${styleVariables?.prefixDefaultClassName}_btn_container_sx`,\r\n sx: `${styleVariables?.prefixDefaultClassName}_btn_sx`,\r\n };\r\n const style = StyleBuilder({\r\n blnRandomPrefix: false,\r\n blnIsDefaultStyle: true,\r\n blnCbmisStyle: true,\r\n objStyles: {\r\n [classesName?.button]: {\r\n position: \"relative\",\r\n width: \"auto\",\r\n height: \"fit-content\",\r\n minHeight: cssObject?.size?.[cssKeys?.item_sm],\r\n fontWeight: cssObject?.fontWeight?.[cssKeys?.fontWeight_md],\r\n fontSize: cssObject?.text?.size?.body1,\r\n letterSpacing: \"0.02857em\",\r\n textTransform: \"capitalize\",\r\n textAlign: \"center\",\r\n outline: \"none\",\r\n display: \"flex\",\r\n justifyContent: \"center\",\r\n alignItems: \"center\",\r\n flexWrap: \"inherit\",\r\n margin: `${cssObject?.spacing?.[cssKeys?.xs]} ${cssObject?.spacing?.[cssKeys?.auto]}`,\r\n cursor: \"pointer\",\r\n transition: \"all .5s ease\",\r\n boxSizing: cssObject?.boxSizing?.[cssKeys?.borderBox],\r\n border: `${cssObject?.size?.[cssKeys?.border_sm]} ${cssObject?.border?.[cssKeys?.border]?.solid} ${cssObject?.color?.[cssKeys?.transparent]}`,\r\n whiteSpace: \"nowrap\",\r\n overflow: \"hidden\",\r\n textOverflow: \"ellipsis\",\r\n },\r\n [classesName?.btn_icon]: {\r\n display: \"flex\",\r\n flexDirection: \"column\",\r\n alignItems: \"center\",\r\n justifyContent: \"center\",\r\n position: \"relative\",\r\n color: cssObject?.color?.[cssKeys?.currentColor],\r\n },\r\n [classesName?.btn_label]: {\r\n cursor: \"pointer\",\r\n color: cssObject?.color?.[cssKeys?.currentColor],\r\n padding: `0 ${cssObject?.spacing?.[cssKeys?.xs]}`,\r\n margin: \"auto\",\r\n },\r\n },\r\n });\r\n\r\n const styleSx = StyleBuilder({\r\n blnRandomPrefix: true,\r\n blnIsDefaultStyle: false,\r\n blnCbmisStyle: true,\r\n objStyles: {\r\n [classesName?.sx]: (props) => {\r\n return {\r\n borderRadius: cssObject?.border?.[cssKeys?.rounded]?.xs,\r\n lineHeight: `${cssObject?.spacing?.[cssKeys?.xs]}`,\r\n ...btnStyleClass(props),\r\n ...btnSize(props),\r\n ...props?.sx,\r\n };\r\n },\r\n },\r\n });\r\n\r\n const defaultStyle = (props) => {\r\n return {\r\n color: props?.color === \"light\" || props?.color === \"#fff\" || props?.color === \"transparent\" ? \"dark\" : \"#fff\",\r\n background: styleFunction.checkColorReturnValue(props?.color || cssObject?.color?.primary),\r\n \"&active\": {\r\n boxShadow: cssObject?.boxShadow?.[cssKeys?.lg],\r\n },\r\n \"&hover\": {\r\n boxShadow: cssObject?.boxShadow?.[cssKeys?.lg],\r\n opacity: 0.9,\r\n },\r\n };\r\n };\r\n const btnStyleClass = (props) => {\r\n const getStyle = String(props?.mode).toLowerCase();\r\n switch (getStyle) {\r\n case \"outlined\":\r\n return {\r\n color: styleFunction.checkColorReturnValue(props?.color || cssObject?.color?.primary),\r\n border: `${cssObject?.size?.[cssKeys?.border_sm]} ${cssObject?.border?.[cssKeys?.border]?.solid} ${styleFunction.checkColorReturnValue(props?.color || cssObject?.color?.primary)}`,\r\n background: cssObject?.color?.[cssKeys?.transparent],\r\n \"&active\": {\r\n boxShadow: cssObject?.boxShadow?.[cssKeys?.lg],\r\n },\r\n \"&hover\": {\r\n boxShadow: cssObject?.boxShadow?.[cssKeys?.lg],\r\n },\r\n };\r\n case \"contained\":\r\n return defaultStyle(props);\r\n case \"link\":\r\n return {\r\n color: styleFunction.checkColorReturnValue(props?.color || cssObject?.color?.primary),\r\n border: `${cssObject?.size?.[cssKeys?.border_sm]} ${cssObject?.border?.[cssKeys?.border]?.solid} ${cssObject?.color?.[cssKeys?.transparent]}`,\r\n background: cssObject?.color?.[cssKeys?.transparent],\r\n \"&active\": {\r\n boxShadow: cssObject?.boxShadow?.[cssKeys?.inner],\r\n },\r\n \"&hover\": {\r\n boxShadow: cssObject?.boxShadow?.[cssKeys?.shadow],\r\n },\r\n };\r\n default:\r\n return defaultStyle(props);\r\n }\r\n };\r\n\r\n const btnSize = (props) => {\r\n const getSize = String(props?.size).toLowerCase();\r\n switch (getSize) {\r\n case \"sm\":\r\n return {\r\n padding: cssObject?.spacing?.[cssKeys?.sm],\r\n fontSize: cssObject?.text?.size?.body3,\r\n \".cbmis_icon_container_in_btn\": {\r\n padding: 0,\r\n margin: 0,\r\n },\r\n };\r\n case \"md\":\r\n return {\r\n padding: `${cssObject?.spacing?.[cssKeys?.md]} ${cssObject?.spacing?.[cssKeys?.lg]}`,\r\n fontSize: cssObject?.text?.size?.body2,\r\n \".cbmis_icon_container_in_btn\": {\r\n fontSize: cssObject?.text?.size?.body2,\r\n },\r\n };\r\n case \"lg\":\r\n return {\r\n padding: `${cssObject?.spacing?.[cssKeys?.lg]} ${cssObject?.spacing?.[cssKeys?.xl]}`,\r\n fontSize: cssObject?.text?.size?.body1,\r\n \".cbmis_icon_container_in_btn\": {\r\n fontSize: cssObject?.text?.size?.body1,\r\n },\r\n };\r\n default:\r\n return {\r\n padding: `${cssObject?.spacing?.[cssKeys?.md]} ${cssObject?.spacing?.[cssKeys?.lg]}`,\r\n fontSize: cssObject?.text?.size?.body1,\r\n \".cbmis_icon_container_in_btn\": {\r\n fontSize: cssObject?.text?.size?.body1,\r\n },\r\n };\r\n }\r\n };\r\n\r\n const btnIconSize = (size, iconSize = null) => {\r\n if (iconSize) {\r\n return iconSize;\r\n } else {\r\n const getSize = String(size).toLowerCase();\r\n switch (getSize) {\r\n case \"sm\":\r\n return cssObject?.text?.size?.body3;\r\n case \"md\":\r\n return cssObject?.text?.size?.body3;\r\n case \"lg\":\r\n return cssObject?.text?.size?.body1;\r\n default:\r\n return cssObject?.text?.size?.body1;\r\n }\r\n }\r\n };\r\n\r\n return {\r\n classesName,\r\n style,\r\n styleSx,\r\n btnIconSize,\r\n };\r\n};\r\n","import { ContextThemeProvider, StyleBuilder, cssKeys, mainTheme, styleFunction, styleVariables } from \"@cbmisorg/styles\";\r\nimport React, { useContext } from \"react\";\r\n\r\nconst className = `${styleVariables?.prefixDefaultClassName}_error_message`\r\nconst errorMsgStyle=(objThemeInfo)=>{\r\n const cssObject = objThemeInfo?.cssObject || mainTheme?.cssObject;\r\n\r\n const style = StyleBuilder({\r\n blnRandomPrefix: true,\r\n blnIsDefaultStyle: false,\r\n blnCbmisStyle: true,\r\n objStyles: {\r\n [className]:(props)=>{\r\n return{\r\n fontSize: cssObject?.text?.size?.[cssKeys?.caption],\r\n padding: `${cssObject?.spacing?.[cssKeys?.px]} ${cssObject?.spacing?.[cssKeys?.sm]}`,\r\n display:\"block\",\r\n position:\"relative\",\r\n width:\"max-content\",\r\n textAlign:\"start\",\r\n margin:0,\r\n color: styleFunction.checkColorReturnValue(props?.blnError?\"error\": \"currentColor\"),\r\n\r\n }\r\n },\r\n }\r\n });\r\n\r\n return {style}\r\n}\r\n\r\nconst ErrorMessage = (props) => {\r\n const { message=null, rest } = props;\r\n if(message){\r\n return \r\n }\r\n return null;\r\n};\r\n\r\nconst ErrorMessageChild = (props) => {\r\n const theTheme = useContext(ContextThemeProvider);\r\n const { message=null, blnError=false, rest } = props;\r\n const {style} = errorMsgStyle(theTheme)\r\n const classes= style({message:message?true:false, blnError: blnError})\r\n\r\n return {message} \r\n};\r\n\r\n\r\nexport default ErrorMessage;\r\n","export function checkParseObject(object) {\r\n try {\r\n if (object === undefined || object === null) {\r\n throw new Error(\"Unsupported data-type\");\r\n }\r\n if (typeof object === \"string\") {\r\n return JSON.parse(object);\r\n } else if (typeof object === \"object\") {\r\n return object;\r\n } else {\r\n throw new Error(\"Unsupported data-type\");\r\n }\r\n } catch (error) {\r\n return {};\r\n }\r\n }\r\n\r\n ","import React, { forwardRef, useContext, useEffect, useId } from \"react\";\r\nimport { styleFunction, ContextThemeProvider } from \"@cbmisorg/styles\";\r\nimport CheckboxGroupStyle from \"./CheckboxGroupStyle\";\r\nimport ErrorBoundary from \"../../_helper/errorHandeling/ErrorBoundary/ErrorBoundary\";\r\nimport ErrorMessage from \"../ErrorMessage/ErrorMessage\";\r\nimport { checkParseObject } from \"../../_helper/functions\";\r\n\r\nconst CheckboxGroup = forwardRef((/**@type {any}*/ props, ref) => {\r\n const {\r\n currentLang = \"eng\",\r\n defaultLang = \"eng\",\r\n label,\r\n options,\r\n children,\r\n display,\r\n color,\r\n mode,\r\n sx,\r\n hidden,\r\n disabled,\r\n dir,\r\n className,\r\n value = null,\r\n defaultValue = null,\r\n id,\r\n errorMessage,\r\n helperMessage,\r\n blnMenuInputList=true,\r\n ...rest\r\n } = props;\r\n const comID = String(useId()).slice(1, -1) + \"checkbox\" || id;\r\n const theTheme = useContext(ContextThemeProvider);\r\n const { classesName, style, styleSx } = CheckboxGroupStyle(theTheme);\r\n const classes = style();\r\n const classesSx = styleSx({ sx, color, display, mode, disabled });\r\n const itemClasses = styleFunction.getClassName(\r\n classes?.[classesName?.checkbox_container],\r\n classesSx?.[classesName?.checkbox_container],\r\n classesSx?.[classesName?.sx],\r\n styleFunction.CheckDirectionItem(dir),\r\n styleFunction.CheckDisabledItem(disabled),\r\n styleFunction.CheckHiddenItem(hidden),\r\n styleFunction.checkExistsMargin(rest),\r\n styleFunction.checkExistsPadding(rest),\r\n className\r\n );\r\n\r\n const CheckboxComp = () => {\r\n let lstOptions = [];\r\n if (children) {\r\n lstOptions = children;\r\n } else if (options) {\r\n lstOptions = options;\r\n }\r\n const funOptValue = (opt) => {\r\n const theValue = checkParseObject(value || defaultValue || [])?.map((item) => {\r\n return item?.key? item?.key : item;\r\n });\r\n return theValue.includes(String(typeof opt === \"object\" ? opt?.key : opt)) || theValue.includes(typeof opt === \"object\" ? opt?.key : opt);\r\n };\r\n\r\n return (\r\n \r\n {!label ? null :
{label} }\r\n {lstOptions?.map((opt, index) => {\r\n const blnChecked = funOptValue(opt);\r\n\r\n return (\r\n
\r\n \r\n \r\n \r\n {opt?.props?.children || opt?.props?.value || typeof opt?.jsx === \"function\"\r\n ? opt?.jsx()\r\n : typeof opt?.value !== \"object\"\r\n ? opt?.value\r\n : opt?.value?.[currentLang] || opt?.value?.[defaultLang] || \"\"}\r\n \r\n
\r\n \r\n );\r\n })}\r\n
\r\n
\r\n );\r\n };\r\n useEffect(() => {}, [currentLang, label, options, children, display, color, mode, sx, hidden, disabled, dir, className, value, defaultValue, id, errorMessage, helperMessage, blnMenuInputList]);\r\n return (\r\n \r\n \r\n \r\n \r\n );\r\n});\r\n\r\nexport default CheckboxGroup;\r\n","import { StyleBuilder, styleVariables, cssKeys, mainTheme, styleFunction } from \"@cbmisorg/styles\";\r\n\r\nexport default (objThemeInfo) => {\r\n const cssObject = objThemeInfo?.cssObject || mainTheme?.cssObject;\r\n const currentBaseSize = objThemeInfo?.currentBaseSize || mainTheme?.currentBaseSize;\r\n\r\n const classesName = {\r\n checkbox_container: `${styleVariables?.prefixDefaultClassName}_checkbox_container`,\r\n checkbox: `${styleVariables?.prefixDefaultClassName}_checkbox`,\r\n checkbox_opt_label: `${styleVariables?.prefixDefaultClassName}_checkbox_opt_label`,\r\n checkbox_opt: `${styleVariables?.prefixDefaultClassName}_checkbox_opt`,\r\n checkbox_label: `${styleVariables?.prefixDefaultClassName}_checkbox_label`,\r\n sx: `${styleVariables?.prefixDefaultClassName}_checkbox_sx`,\r\n };\r\n const style = StyleBuilder({\r\n blnRandomPrefix: false,\r\n blnIsDefaultStyle: true,\r\n blnCbmisStyle: true,\r\n objStyles: {\r\n [classesName?.checkbox_container]: {\r\n position: \"relative\",\r\n width: \"100%\",\r\n margin: 0,\r\n display: \"inline-block\",\r\n },\r\n [classesName?.checkbox]: {\r\n appearance: \"none\",\r\n WebkitAppearance: \"none\",\r\n /* remove default */\r\n display: \"flex\",\r\n alignSelf: \"flex-start\",\r\n position: \"relative\",\r\n borderRadius: cssObject?.border?.[cssKeys?.rounded]?.xs,\r\n cursor: \"pointer\",\r\n verticalAlign: \"middle\",\r\n boxShadow: \"0 0 0 1px rgba(0, 0, 0, 0.1)\",\r\n backgroundColor: cssObject?.color?.[cssKeys?.light],\r\n WebkitTransition: \"background-position .15s cubic-bezier(.8, 0, 1, 1), -webkit-transform .25s cubic-bezier(.8, 0, 1, 1)\",\r\n outline: \"none\",\r\n margin: 0,\r\n top: \".7rem\",\r\n \"&active\": {\r\n WebkitTransform: \"scale(1.5)\",\r\n WebkitTransition: \"-webkit-transform .1s cubic-bezier(0, 0, .2, 1)\",\r\n },\r\n \"&after\": {\r\n content: \"\",\r\n position: \"absolute\",\r\n display: \"block\",\r\n top: \"38%\",\r\n left: \"10%\",\r\n margin: 0,\r\n scale: \"0\",\r\n transform: \"translate(-50%, -50%)\",\r\n transition: \".1s ease-in-out\",\r\n },\r\n \"&before\": {\r\n content: \"\",\r\n position: \"absolute\",\r\n display: \"block\",\r\n top: \"38%\",\r\n left: \"10%\",\r\n margin: 0,\r\n scale: \"0\",\r\n transform: \"translate(-50%, -50%)\",\r\n transition: \".1s ease-in-out\",\r\n },\r\n },\r\n [classesName?.checkbox_label]: {\r\n display: \"flex\",\r\n alignItems: \"center\",\r\n fontWeight: \"600\",\r\n fontSize: cssObject?.text?.size?.[cssKeys?.subtitle3],\r\n textAlign: \"start\",\r\n width: \"100%\",\r\n },\r\n [classesName?.checkbox_opt]: {\r\n display: \"flex\",\r\n width: \"inherit\",\r\n justifyContent: \"flex-start\",\r\n alignItems: \"baseline\",\r\n // flexWrap: \"wrap\",\r\n },\r\n [classesName?.checkbox_opt_label]: {\r\n display: \"inline-block\",\r\n width: \"max-content\",\r\n margin: \"0px\",\r\n },\r\n },\r\n });\r\n\r\n // const styleSx = StyleBuilder({\r\n // blnRandomPrefix: true,\r\n // blnIsDefaultStyle: false,\r\n // blnCbmisStyle: true,\r\n // objStyles: {\r\n // [classesName?.checkbox_container]: (props) => {\r\n // return {\r\n // padding: `${cssObject?.spacing?.[cssKeys?.px]} ${cssObject?.spacing?.[cssKeys?.xs]}`,\r\n // display: `${String(props?.display).toLowerCase() === \"inline\" && !props?.blnMenuInputList ? \"flex\" : \"block\"}`,\r\n // width: props?.blnMenuInputList ? \"99%\" : \"maxContent\",\r\n // // flexWrap: \"wrap\",\r\n // };\r\n // },\r\n // [classesName?.checkbox]: (props) => {\r\n // return {\r\n // minWidth: props?.blnMenuInputList ? 0 : cssObject?.size?.[cssKeys?.item_2xs],\r\n // width: props?.blnMenuInputList ? 0 : cssObject?.size?.[cssKeys?.item_2xs],\r\n // height: props?.blnMenuInputList ? 0 : cssObject?.size?.[cssKeys?.item_2xs],\r\n // opacity: props?.blnMenuInputList ? 0 : 1,\r\n // \"&hover\": {\r\n // backgroundColor: cssObject?.color?.[`${cssKeys?.primary}_1`],\r\n // ...props?.sx?.[\"&hover\"],\r\n // },\r\n // \"&checked\": {\r\n // WebkitTransition: \"background-position .1s .15s cubic-bezier(0, 0, .2, 1),-webkit-transform .25s cubic-bezier(0, 0, .2, 1)\",\r\n // backgroundImage: props?.disabled\r\n // ? cssObject?.color?.[cssKeys?.disabled]\r\n // : `-webkit-linear-gradient(90deg, ${styleFunction?.checkColorReturnValue(\r\n // `${props?.color || cssObject?.color?.[`${cssKeys?.primary}_6`]}`\r\n // )} 0%, ${styleFunction?.checkColorReturnValue(`${props?.color || cssObject?.color?.[`${cssKeys?.primary}`]}f9`)} 65%, ${styleFunction?.checkColorReturnValue(\r\n // `${props?.color || cssObject?.color?.[`${cssKeys?.primary}_8`]}63`\r\n // )} 100%)`,\r\n // backgroundRepeat: \"no-repeat\",\r\n // boxShadow: `0 0 0 0.05em ${cssObject?.color?.[cssKeys?.white]}, 0 0 0.15em 0.1em ${\r\n // props?.disabled ? cssObject?.color?.[cssKeys?.disabled] : cssObject?.color?.[cssKeys?.primary]\r\n // }`,\r\n // ...getMode(props),\r\n // ...props?.sx?.[\"&checked\"],\r\n // \"&+\": props?.blnMenuInputList\r\n // ? {\r\n // [`.${classesName?.checkbox_opt_label}`]: {\r\n // backgroundColor: cssObject?.color?.[`${cssKeys?.primary}_1`],\r\n // color: cssObject?.color?.[cssKeys?.primary],\r\n // },\r\n // }\r\n // : null,\r\n // },\r\n // };\r\n // },\r\n // [classesName?.checkbox_opt]: (props) => {\r\n // return {\r\n // color: cssObject?.color?.[cssKeys?.bodyColor],\r\n // fontSize: cssObject?.text?.size?.[cssKeys?.body3],\r\n // margin: \"auto 0px\",\r\n // // margin:String(props?.display).toLowerCase() === \"inline\"? `${cssObject?.spacing?.[cssKeys?.sm]}` : `${cssObject?.spacing?.[cssKeys?.sm]} ${cssObject?.spacing?.[cssKeys?.xs]}`,\r\n // justlyContent: \"center\",\r\n // alignItem: \"center\",\r\n // textAlign: \"start\",\r\n // width: props?.blnMenuInputList ? \"100%\" : \"inherit\",\r\n // [`.${classesName?.checkbox_opt_label}`]: {\r\n // padding:\r\n // String(props?.display).toLowerCase() === \"inline\"\r\n // ? `${cssObject?.spacing?.[cssKeys?.sm]}`\r\n // : `${cssObject?.spacing?.[cssKeys?.sm]} ${cssObject?.spacing?.[cssKeys?.xs]}`,\r\n // fontSize: cssObject?.text?.size?.[cssKeys?.body3],\r\n // ...(props?.blnMenuInputList\r\n // ? {\r\n // width: \"100%\",\r\n // cursor: \"pointer\",\r\n // \"&hover\": {\r\n // backgroundColor: cssObject?.color?.[cssKeys?.light],\r\n // },\r\n // }\r\n // : null),\r\n // },\r\n // };\r\n // },\r\n // [classesName?.checkbox_label]: {\r\n // fontSize: cssObject?.text?.size?.[cssKeys?.subtitle3],\r\n // textAlign: \"start\",\r\n // maxWidth: \"fit-content\",\r\n // margin: 0,\r\n // },\r\n // [classesName?.sx]: (props) => {\r\n // return {\r\n // ...props?.sx,\r\n // };\r\n // },\r\n // },\r\n // });\r\n\r\n const styleSx = StyleBuilder({\r\n blnRandomPrefix: true,\r\n blnIsDefaultStyle: false,\r\n blnCbmisStyle: true,\r\n objStyles: {\r\n [classesName?.checkbox_container]: (props) => {\r\n return {\r\n padding: `${cssObject?.spacing?.[cssKeys?.px]}`,\r\n margin: \"auto\",\r\n display: `${String(props?.display).toLowerCase() === \"inline\" && !props?.blnMenuInputList ? \"flex\" : \"block\"}`,\r\n width: props?.blnMenuInputList ? \"99%\" : \"maxContent\",\r\n // flexWrap: \"wrap\",\r\n };\r\n },\r\n [classesName?.checkbox]: (props) => {\r\n return {\r\n minWidth: props?.blnMenuInputList ? 0 : cssObject?.size?.[cssKeys?.item_2xs],\r\n width: props?.blnMenuInputList ? 0 : cssObject?.size?.[cssKeys?.item_2xs],\r\n height: props?.blnMenuInputList ? 0 : cssObject?.size?.[cssKeys?.item_2xs],\r\n opacity: props?.blnMenuInputList ? 0 : 1,\r\n \"&hover\": {\r\n backgroundColor: cssObject?.color?.[`${cssKeys?.primary}_1`],\r\n ...props?.sx?.[\"&hover\"],\r\n },\r\n \"&checked\": {\r\n WebkitTransition: \"background-position .1s .15s cubic-bezier(0, 0, .2, 1),-webkit-transform .25s cubic-bezier(0, 0, .2, 1)\",\r\n backgroundImage: props?.disabled\r\n ? cssObject?.color?.[cssKeys?.disabled]\r\n : `-webkit-linear-gradient(90deg, ${styleFunction?.checkColorReturnValue(\r\n `${props?.color || cssObject?.color?.[`${cssKeys?.primary}_6`]}`\r\n )} 0%, ${styleFunction?.checkColorReturnValue(`${props?.color || cssObject?.color?.[`${cssKeys?.primary}`]}f9`)} 65%, ${styleFunction?.checkColorReturnValue(\r\n `${props?.color || cssObject?.color?.[`${cssKeys?.primary}_8`]}63`\r\n )} 100%)`,\r\n backgroundRepeat: \"no-repeat\",\r\n boxShadow: `0 0 0 0.05em ${cssObject?.color?.[cssKeys?.white]}, 0 0 0.15em 0.1em ${\r\n props?.disabled ? cssObject?.color?.[cssKeys?.disabled] : cssObject?.color?.[cssKeys?.primary]\r\n }`,\r\n ...getMode(props),\r\n ...props?.sx?.[\"&checked\"],\r\n \"&+\": props?.blnMenuInputList\r\n ? {\r\n [`.${classesName?.checkbox_opt_label}`]: {\r\n backgroundColor: cssObject?.color?.[`${cssKeys?.primary}_1`],\r\n color: cssObject?.color?.[cssKeys?.primary],\r\n },\r\n }\r\n : null,\r\n },\r\n };\r\n },\r\n },\r\n [classesName?.checkbox_opt]: (props) => {\r\n return {\r\n color: cssObject?.color?.[cssKeys?.currentColor],\r\n fontSize: cssObject?.text?.size?.[cssKeys?.body3],\r\n margin: \"auto 0px\",\r\n // margin:String(props?.display).toLowerCase() === \"inline\"? `${cssObject?.spacing?.[cssKeys?.sm]}` : `${cssObject?.spacing?.[cssKeys?.sm]} ${cssObject?.spacing?.[cssKeys?.xs]}`,\r\n justlyContent: \"center\",\r\n alignItem: \"center\",\r\n textAlign: \"start\",\r\n width: props?.blnMenuInputList ? \"100%\" : \"inherit\",\r\n [`.${classesName?.checkbox_opt_label}`]: {\r\n padding:\r\n String(props?.display).toLowerCase() === \"inline\"\r\n ? `${cssObject?.spacing?.[cssKeys?.sm]}`\r\n : `${cssObject?.spacing?.[cssKeys?.sm]} ${cssObject?.spacing?.[cssKeys?.sm]}`,\r\n fontSize: cssObject?.text?.size?.[cssKeys?.body3],\r\n ...(props?.blnMenuInputList\r\n ? {\r\n width: \"100%\",\r\n cursor: \"pointer\",\r\n \"&hover\": {\r\n backgroundColor: cssObject?.color?.[cssKeys?.light],\r\n },\r\n }\r\n : null),\r\n },\r\n };\r\n },\r\n [classesName?.checkbox_label]: {\r\n fontSize: cssObject?.text?.size?.[cssKeys?.subtitle3],\r\n textAlign: \"start\",\r\n maxWidth: \"fit-content\",\r\n margin: 0,\r\n },\r\n [classesName?.sx]: (props) => {\r\n return {\r\n ...props?.sx,\r\n };\r\n },\r\n });\r\n\r\n const getMode = (props) => {\r\n switch (String(props?.mode)?.toLowerCase()) {\r\n case \"cross\":\r\n return {\r\n \"&after\": {\r\n content: \"\",\r\n width: \"75%\",\r\n height: \"20%\",\r\n backgroundColor: cssObject?.color?.[cssKeys?.bodyColorBg],\r\n rotate: \"45deg\",\r\n borderRadius: cssObject?.border?.[cssKeys?.rounded]?.xs,\r\n transition: \".1s ease-in-out\",\r\n transform: \"rotate(180deg)\",\r\n scale: 1,\r\n boxShadow: `0 0 0 0.05em ${cssObject?.color?.[cssKeys?.white]}, 0 0 0.15em 0.1em ${cssObject?.color?.[cssKeys?.primary]}`,\r\n },\r\n \"&before\": {\r\n content: \"\",\r\n width: \"75%\",\r\n height: \"20%\",\r\n backgroundColor: cssObject?.color?.[cssKeys?.bodyColorBg],\r\n borderRadius: cssObject?.border?.[cssKeys?.rounded]?.xs,\r\n rotate: \"-45deg\",\r\n transition: \".1s ease-in-out\",\r\n transform: \"rotate(180deg)\",\r\n scale: 1,\r\n boxShadow: `0 0 0 0.05em ${cssObject?.color?.[cssKeys?.white]}, 0 0 0.15em 0.1em ${cssObject?.color?.[cssKeys?.primary]}`,\r\n },\r\n };\r\n case \"indeterminate\":\r\n return {\r\n \"&before\": {\r\n width: \"60%\",\r\n height: \"20%\",\r\n left: \"20%\",\r\n backgroundColor: cssObject?.color?.[cssKeys?.bodyColorBg],\r\n borderRadius: cssObject?.border?.[cssKeys?.rounded]?.xs,\r\n transition: \".1s ease-in-out\",\r\n transform: \"rotate(180deg)\",\r\n scale: 1,\r\n boxShadow: `0 0 0 0.05em ${cssObject?.color?.[cssKeys?.primary]}, 0 0 0.15em 0.1em ${cssObject?.color?.[cssKeys?.white]}`,\r\n },\r\n };\r\n default:\r\n return {\r\n \"&before\": {\r\n width: \"65%\",\r\n height: \"35%\",\r\n top: \"15%\",\r\n borderBottom: `${cssObject?.size?.[cssKeys?.border_sm]} solid ${cssObject?.color?.[cssKeys?.bodyColorBg]}`,\r\n borderLeft: `${cssObject?.size?.[cssKeys?.border_sm]} solid ${cssObject?.color?.[cssKeys?.bodyColorBg]}`,\r\n borderRadius: cssObject?.border?.[cssKeys?.rounded]?.px,\r\n rotate: \"135deg\",\r\n transition: \".1s ease-in-out\",\r\n transform: \"rotate(180deg)\",\r\n scale: 1,\r\n },\r\n };\r\n }\r\n };\r\n return {\r\n classesName,\r\n style,\r\n styleSx,\r\n };\r\n};\r\n","import { StyleBuilder, cssKeys, mainTheme, styleFunction, styleVariables } from \"@cbmisorg/styles\";\r\n\r\nexport default (objThemeInfo) => {\r\n const cssObject = objThemeInfo?.cssObject || mainTheme?.cssObject;\r\n const currentBaseSize = objThemeInfo?.currentBaseSize || mainTheme?.currentBaseSize;\r\n\r\n const classesName = {\r\n menu_container: `${styleVariables?.prefixDefaultClassName}_menu_container`,\r\n menu: `${styleVariables?.prefixDefaultClassName}_menu`,\r\n menu_open: `${styleVariables?.prefixDefaultClassName}_menu_open`,\r\n body_back_menu_open: `${styleVariables?.prefixDefaultClassName}_body_back_menu_open`,\r\n menu_bg_dialog_open: `${styleVariables?.prefixDefaultClassName}_menu_bg_dialog_open`,\r\n\r\n menu_item: `${styleVariables?.prefixDefaultClassName}_menu_item`,\r\n menu_item_selected: `${styleVariables?.prefixDefaultClassName}_menu_item_selected`,\r\n menu_item_outlined: `${styleVariables?.prefixDefaultClassName}_menu_item_outlined`,\r\n menu_item_head_content: `${styleVariables?.prefixDefaultClassName}_menu_item_head_content`,\r\n menu_item_head: `${styleVariables?.prefixDefaultClassName}_menu_item_head`,\r\n menu_item_item_content: `${styleVariables?.prefixDefaultClassName}_menu_item_item_content`,\r\n menu_item_footer: `${styleVariables?.prefixDefaultClassName}_menu_item_footer`,\r\n\r\n sx: `${styleVariables?.prefixDefaultClassName}_menu_sx`,\r\n sxItem: `${styleVariables?.prefixDefaultClassName}_menu_item_sx`,\r\n };\r\n\r\n const style = StyleBuilder({\r\n blnRandomPrefix: false,\r\n blnIsDefaultStyle: true,\r\n blnCbmisStyle: true,\r\n objStyles: {\r\n [classesName?.menu_container]: {\r\n position: \"relative\",\r\n left: 0,\r\n right: 0,\r\n height: \"max-content\",\r\n display: \"block\",\r\n },\r\n [classesName?.menu]: {\r\n // textAlign: \"start\",\r\n // transition: `${currentBaseSize}s linear`,\r\n // minWidth: \"max-content\",\r\n // width: cssObject?.size?.[cssKeys?.full],\r\n // position: \"absolute\",\r\n // display: \"-webkit-fill-available\",\r\n // top:0,\r\n\r\n listStyle: \"none\",\r\n position: \"fixed\",\r\n display: \"none\",\r\n flexDirection: \"row\",\r\n justifyContent: \"center\",\r\n /* align-content: center, */\r\n flexWrap: \"wrap\",\r\n overflow: \"auto\",\r\n margin: \"0\",\r\n padding: \"0\",\r\n zIndex: \"-1 !important\",\r\n transition: \"height .5s\",\r\n // maxHeight: `${currentBaseSize * 110}rem`,\r\n },\r\n [classesName?.menu_item]: {\r\n width: \"90%\",\r\n margin: \"auto\",\r\n display: cssObject?.display?.[cssKeys?.flex],\r\n flex: 1,\r\n justifyContent: \"space-between\",\r\n alignItems: \"center\",\r\n \"&hover\": {\r\n background: cssObject?.color?.[cssKeys?.bodyColorLight],\r\n cursor: \"pointer\",\r\n },\r\n },\r\n [classesName?.menu_item_head]: {\r\n justifyContent: \"center\",\r\n textAlign: \"center\",\r\n // padding:cssObject?.spacing?.[cssKeys?.xs],\r\n background: \"transparent\",\r\n display: \"flex\",\r\n width: \"maxContent\",\r\n margin: cssObject?.spacing?.[cssKeys?.xs],\r\n },\r\n [classesName?.menu_item_item_content]: {\r\n textAlign: \"start\",\r\n background: \"transparent\",\r\n // padding:cssObject?.spacing?.[cssKeys?.xs],\r\n display: \"flex\",\r\n alignItems: \"center\",\r\n minWidth: \"75%\",\r\n // width: \"100%\",\r\n justifyContent: \"flex-start\",\r\n },\r\n [classesName?.menu_item_footer]: {\r\n display: \"flex\",\r\n alignSelf: \"center\",\r\n justifyContent: \"center\",\r\n textAlign: \"center\",\r\n width: \"maxContent\",\r\n margin: cssObject?.spacing?.[cssKeys?.xs],\r\n background: \"transparent\",\r\n },\r\n },\r\n });\r\n const styleSx = StyleBuilder({\r\n blnRandomPrefix: true,\r\n blnIsDefaultStyle: false,\r\n blnCbmisStyle: true,\r\n objStyles: {\r\n [classesName?.menu_container]: (props) => {\r\n return {\r\n minWidth: props?.blnFullWidth ? \"135px\" :\"1px\",\r\n width: props?.blnFullWidth ? \"100%\" : \"maxContent\",\r\n };\r\n },\r\n [classesName?.menu]: (props) => {\r\n return {\r\n background: styleFunction.checkColorReturnValue(cssObject?.color?.bodyColorBgLight),\r\n color: styleFunction.checkColorReturnValue(cssObject?.color?.bodyColor),\r\n fontSize: cssObject?.text?.size?.body2,\r\n height: 0,\r\n boxShadow: cssObject?.boxShadow?.[cssKeys?.lg],\r\n borderRadius: cssObject?.border?.[cssKeys?.rounded]?.sm,\r\n \r\n };\r\n },\r\n [classesName?.body_back_menu_open]: (props) => {\r\n return {\r\n \"&>\": {\r\n \"&*\": {\r\n zIndex: \"-1 !important\",\r\n },\r\n },\r\n };\r\n },\r\n [classesName?.menu_open]: (props) => {\r\n return {\r\n display: \"flex\",\r\n justifyContent: \"flex-start\",\r\n alignItems: \"stretch\",\r\n alignContent: \"stretch\",\r\n height: \"min-content\",\r\n zIndex: \"1100 !important\",\r\n minWidth:`${currentBaseSize * 25}rem`,\r\n width: \"min-content\",\r\n maxWidth: \"100%\",\r\n // maxHeight: `${currentBaseSize * props?.itemNumber * 100}rem`,\r\n pointerEvents: \"auto !important\",\r\n\r\n \"&>\": {\r\n \"&*\": {\r\n zIndex: \"1110 !important\",\r\n // pointerEvents: \"auto !important\",\r\n },\r\n },\r\n };\r\n },\r\n [classesName?.menu_bg_dialog_open]: (props) => {\r\n return {\r\n position: \"fixed\",\r\n display: \"block\",\r\n width: \"100vw\",\r\n top: 0,\r\n left: 0,\r\n height: \"100vh\",\r\n zIndex: \"1000 !important\",\r\n };\r\n },\r\n \r\n [classesName?.sx]: (props) => {\r\n return {\r\n ...props?.sx,\r\n };\r\n },\r\n },\r\n });\r\n\r\n const styleMenuItemSx = StyleBuilder({\r\n blnRandomPrefix: true,\r\n blnIsDefaultStyle: false,\r\n blnCbmisStyle: true,\r\n objStyles: {\r\n [classesName?.menu_item]: (props) => {\r\n return {\r\n \"&hover\":{\r\n color: cssObject?.color?.[cssKeys?.primary],\r\n background: props?.onClick ? cssObject?.color?.[`${cssKeys?.primary}_1`]: null,\r\n }\r\n };\r\n },\r\n [classesName?.sxItem]: (props) => {\r\n return {\r\n padding: `0px`,\r\n ...(props?.selected\r\n ? {\r\n color: cssObject?.color?.[cssKeys?.primary],\r\n background: cssObject?.color?.[cssKeys?.bodyColorLight],\r\n }\r\n : {}),\r\n ...(props?.outlined\r\n ? {\r\n borderBottom: `${cssObject?.size?.[cssKeys?.border_xs]} ${cssObject?.border?.[cssKeys?.border]?.solid} ${styleFunction.checkColorReturnValue(cssObject?.color?.bodyColor)}`,\r\n }\r\n : {}),\r\n ...props?.sx,\r\n };\r\n },\r\n },\r\n });\r\n\r\n return {\r\n classesName,\r\n style,\r\n styleSx,\r\n styleMenuItemSx,\r\n };\r\n};\r\n","import React, { forwardRef, useContext, useEffect, useId, useRef, useState } from \"react\";\r\nimport { ContextThemeProvider, styleFunction } from \"@cbmisorg/styles\";\r\nimport MenuStyle from \"./MenuStyle\";\r\n\r\nconst funGetWidthPortionRef = (elementRef) => {\r\n if (elementRef?.current) {\r\n const react = elementRef.current.getBoundingClientRect();\r\n return {\r\n height: react?.height,\r\n width: react?.width,\r\n bottom: react?.bottom,\r\n top: react?.top,\r\n right: react?.right,\r\n left: react?.left,\r\n x: react?.x,\r\n y: react?.y,\r\n };\r\n }\r\n return null;\r\n};\r\n\r\nconst MenuChild = forwardRef((/**@type {any}*/ props, ref) => {\r\n const { open= false, eventClose, jsxOpenEl = null, blnFullWidth = true, blnCloseOutMenuClick = true, sx, id, hidden, disabled, dir, className, ...rest } = props;\r\n \r\n const containerMenuRef = useRef(null);\r\n const theTheme = useContext(ContextThemeProvider);\r\n const { classesName, style, styleSx } = MenuStyle(theTheme);\r\n const classes = style();\r\n const classesSx = styleSx({ sx, open, blnFullWidth, itemNumber : props?.children?.length || 1 });\r\n\r\n let menu_ID = id || useId().replace(/:/g, \"\");\r\n\r\n const itemClasses = styleFunction.getClassName(\r\n classes?.[classesName?.menu],\r\n classesSx?.[classesName?.menu],\r\n classesSx?.[classesName?.menu_open],\r\n classes?.[classesName?.sx],\r\n styleFunction.CheckDirectionItem(dir),\r\n styleFunction.CheckDisabledItem(disabled),\r\n styleFunction.CheckHiddenItem(hidden),\r\n styleFunction.checkExistsMargin(rest),\r\n styleFunction.checkExistsPadding(rest),\r\n className\r\n );\r\n\r\n const funChangeMenuStyle = () => {\r\n if (open) {\r\n const menu = document?.getElementById(menu_ID);\r\n if (menu) {\r\n const actWidth = menu ? menu?.offsetWidth : 0;\r\n const react = funGetWidthPortionRef(containerMenuRef);\r\n menu.style.minWidth = blnFullWidth ? `${react?.width}px` : \"max-content\";\r\n menu.style.top = `${react?.top}px`;\r\n menu.style.height =\"max-content\";\r\n menu.style.blockSize= \"max-content\";\r\n menu.style.inlineSize= \"max-content\";\r\n menu.style.maxHeight =`${window.innerHeight - react?.top -20}px`;\r\n if (!blnFullWidth) {\r\n if (react?.right > react?.left) {\r\n menu.style.right = actWidth + react?.right > window.innerWidth ? `${window.innerWidth - react?.right + 1}px` : `${react?.right - actWidth}px`;\r\n } else {\r\n menu.style.left = actWidth + react?.left > window.innerWidth ? `${window.innerWidth - react?.left + 1}px` : `${react?.left - actWidth}px`;\r\n }\r\n }\r\n }\r\n }\r\n };\r\n\r\n useEffect(() => {\r\n funChangeMenuStyle();\r\n }, [open]);\r\n\r\n useEffect(() => {\r\n window.addEventListener(\"resize\", funChangeMenuStyle);\r\n window.addEventListener(\"scroll\", funChangeMenuStyle, { passive: true });\r\n return () => {\r\n window.removeEventListener(\"resize\", funChangeMenuStyle);\r\n window.removeEventListener(\"scroll\", funChangeMenuStyle);\r\n };\r\n }, []);\r\n\r\n // const dropdownNode = useClickOutside(() => {\r\n // if (eventClose && blnCloseOutMenuClick) {\r\n // // eventClose();\r\n // }\r\n // });\r\n\r\n const funClose = () => {\r\n if (eventClose) {\r\n eventClose();\r\n }\r\n };\r\n\r\n return (\r\n \r\n {!blnCloseOutMenuClick ? null :
}\r\n \r\n \r\n );\r\n});\r\n\r\nconst Menu = forwardRef((/**@type {any}*/ props, ref) => {\r\n const { open, ...rest } = props;\r\n\r\n return !open ? null : ;\r\n});\r\n\r\nexport default Menu;\r\n","import { ContextThemeProvider, styleFunction } from '@cbmisorg/styles';\r\nimport React, { forwardRef, useContext, useId } from 'react'\r\nimport MenuStyle from './MenuStyle';\r\n\r\nconst MenuItem = forwardRef((/**@type {any}*/props, ref) => {\r\n const { headItem, footerItem, outlined, selected, sx, hidden, disabled, dir, className, id, onClick, ...rest } = props;\r\n const theTheme = useContext(ContextThemeProvider);\r\n const {classesName, style, styleMenuItemSx} = MenuStyle(theTheme);\r\n const classes = style();\r\n const classesSx = styleMenuItemSx({sx,selected,outlined,onClick: onClick? true : false});\r\n const itemClasses = styleFunction.getClassName(classes?.[classesName?.menu_item], classesSx?.[classesName?.sxItem], styleFunction.CheckDirectionItem(dir),styleFunction.CheckDisabledItem(disabled), styleFunction.CheckHiddenItem(hidden),styleFunction.checkExistsMargin(rest),styleFunction.checkExistsPadding(rest), className);\r\n const comID = id || String(useId()).slice(1, -1);\r\n\r\n\r\n const handelClicked=(e)=>{\r\n if(onClick){\r\n onClick(e);\r\n }\r\n }\r\n return (\r\n \r\n {!headItem ?null:
{headItem}
}\r\n
\r\n {props.children}\r\n
\r\n
{!footerItem?null:footerItem}
\r\n
\r\n )\r\n});\r\n\r\nexport default MenuItem ","import React, { forwardRef, useContext, useEffect, useId, useRef, useState } from \"react\";\r\nimport { ContextThemeProvider, cssKeys, mainTheme, styleFunction } from \"@cbmisorg/styles\";\r\nimport { Icon } from \"@cbmisorg/icons\";\r\nimport GroupFieldStyle from \"./GroupFieldStyle\";\r\nimport ErrorMessage from \"../ErrorMessage/ErrorMessage\";\r\nimport Typography from \"../../dataDisplay/Typography/Typography\";\r\nimport Menu from \"../../navigation/Menu/Menu\";\r\nimport MenuItem from \"../../navigation/Menu/MenuItem\";\r\nimport Button from \"../Button/Button\";\r\nimport { checkParseObject } from \"../../_helper/functions\";\r\n\r\nconst GroupField = forwardRef((/**@type {any}*/ props, ref) => {\r\n const {\r\n id,\r\n label,\r\n placeholder,\r\n errorMessage = null,\r\n helperMessage,\r\n icon,\r\n adornment,\r\n endIcon,\r\n endAdornment,\r\n mode,\r\n color,\r\n iconColor,\r\n iconSize,\r\n type = \"text\",\r\n value,\r\n defaultValue,\r\n inputDir,\r\n endIconRest = {},\r\n endComponent, // to use in other inputs\r\n onFocus,\r\n onBlur,\r\n onChange,\r\n optionLang = null,\r\n currentLang = \"eng\",\r\n defaultLang = \"eng\",\r\n setCurrentLang, // FORM API\r\n sx,\r\n hidden,\r\n disabled,\r\n dir,\r\n className,\r\n MenuList = null,\r\n ...rest\r\n } = props;\r\n // endIconRest,endComponent, // to use in other inputs\r\n const inputRef = useRef(null);\r\n const theTheme = useContext(ContextThemeProvider);\r\n const { classesName, style, styleSx } = GroupFieldStyle(theTheme);\r\n const classes = style();\r\n const classesSx = styleSx({ sx, color, mode, icon: icon? true: false, adornment, endIcon:endIcon? true: false, endAdornment, dir, inputDir, placeholder, errorMessage, type, menuList: MenuList ? true : false });\r\n const cssObject = theTheme?.cssObject || mainTheme?.cssObject;\r\n const comID = id || String(useId()).slice(1, -1) + \"text\";\r\n const itemClassesContainer = styleFunction.getClassName(\r\n classes?.[classesName?.fieldset_comp_container],\r\n classesSx?.[classesName?.fieldset_comp_container],\r\n styleFunction.CheckDirectionItem(dir),\r\n styleFunction.CheckDisabledItem(disabled),\r\n styleFunction.CheckHiddenItem(hidden),\r\n styleFunction.checkExistsMargin(rest),\r\n styleFunction.checkExistsPadding(rest),\r\n className\r\n );\r\n const itemClasses = styleFunction.getClassName(classes?.[classesName?.fieldset_input], classesSx?.[classesName?.fieldset_input], classesSx?.[classesName?.sx], classesSx?.[classesName?.inputValid]);\r\n const ref_item_container = useRef(null);\r\n const ref_input_action_color = useRef(styleFunction.checkColorReturnValue(cssObject?.color?.[cssKeys?.currentColor]));\r\n\r\n let checkValue = checkParseObject(value || defaultValue);\r\n checkValue = Object?.keys(checkValue)?.length ? checkValue : value || defaultValue || \"\";\r\n\r\n const [initialState, setInitialState] = useState({\r\n currentLangSelected:currentLang || defaultLang,\r\n optionLang: optionLang || {},\r\n openLangMenu: false,\r\n blnIsFull: false,\r\n });\r\n\r\n const handleFocus = (event) => {\r\n ref_item_container.current.style.color = styleFunction.checkColorReturnValue(color ? color :cssObject?.color?.[cssKeys?.primary]);\r\n ref_input_action_color.current = styleFunction.checkColorReturnValue(color ? color : cssObject?.color?.[cssKeys?.primary]);\r\n if (errorMessage) {\r\n ref_item_container.current.style.color = styleFunction.checkColorReturnValue(cssObject?.color?.[cssKeys?.error]);\r\n }\r\n if (onFocus) {\r\n onFocus(event);\r\n }\r\n };\r\n const handleBlur = (event) => {\r\n ref_item_container.current.style.color = styleFunction.checkColorReturnValue(cssObject?.color?.[cssKeys?.borderColor]);\r\n ref_input_action_color.current = styleFunction.checkColorReturnValue(cssObject?.color?.[cssKeys?.borderColor]);\r\n\r\n if (errorMessage) {\r\n ref_item_container.current.style.color = styleFunction.checkColorReturnValue(cssObject?.color?.[cssKeys?.error]);\r\n }\r\n if (onBlur) {\r\n onBlur(event);\r\n }\r\n };\r\n\r\n const handleChange = (event) => {\r\n ref_item_container.current.style.color = styleFunction.checkColorReturnValue(color ? color :cssObject?.color?.[cssKeys?.primary]);\r\n ref_input_action_color.current = styleFunction.checkColorReturnValue(color ? color : cssObject?.color?.[cssKeys?.primary]);\r\n if (errorMessage) {\r\n ref_item_container.current.style.color = styleFunction.checkColorReturnValue(cssObject?.color?.[cssKeys?.error]);\r\n }\r\n ref_item_container.current.style.boxShadow = cssObject?.boxShadow?.input_box_shadow;\r\n if (onChange) {\r\n onChange(event);\r\n }\r\n };\r\n\r\n useEffect(() => {}, [\r\n id,\r\n label,\r\n placeholder,\r\n errorMessage,\r\n helperMessage,\r\n icon,\r\n adornment,\r\n endIcon,\r\n endAdornment,\r\n mode,\r\n color,\r\n iconColor,\r\n iconSize,\r\n type,\r\n inputDir,\r\n endIconRest,\r\n endComponent, // to use in other inputs\r\n onFocus,\r\n onBlur,\r\n onChange,\r\n optionLang,\r\n setCurrentLang, // FORM API\r\n sx,\r\n hidden,\r\n disabled,\r\n dir,\r\n className,\r\n MenuList,\r\n rest,\r\n ]);\r\n\r\n useEffect(() => {\r\n if (errorMessage) {\r\n ref_item_container.current.style.color = styleFunction.checkColorReturnValue(cssObject?.color?.[cssKeys?.error]);\r\n } else {\r\n ref_item_container.current.style.color = ref_input_action_color?.current;\r\n }\r\n }, [errorMessage, ref_input_action_color]);\r\n\r\n useEffect(() => {\r\n if (value || defaultValue) {\r\n inputRef.current.value = Array.isArray(checkValue)\r\n ? checkValue?.map((item) => (typeof item === \"object\" ? item?.[currentLang] || item?.[defaultLang] : item))\r\n : typeof checkValue?.[currentLang] !== \"undefined\"\r\n ? checkValue?.[currentLang]\r\n : String(checkValue);\r\n if (!inputRef.current.value && !optionLang?.[initialState?.currentLangSelected].blnIsMandatory && optionLang?.[initialState?.currentLangSelected].blnIsActive) {\r\n checkValue?.[defaultLang];\r\n }\r\n } else {\r\n inputRef.current.value = \"\";\r\n }\r\n }, [value, defaultValue, currentLang, defaultLang, ref]);\r\n\r\n useEffect(() => {\r\n if(currentLang !== initialState?.currentLangSelected) {\r\n initialState.currentLangSelected = currentLang;\r\n setInitialState({...initialState})\r\n }\r\n },[currentLang]);\r\n\r\n\r\n function openList() {\r\n initialState.openLangMenu = !initialState.openLangMenu;\r\n setInitialState({ ...initialState });\r\n }\r\n\r\n function closeList() {\r\n initialState.openLangMenu = false;\r\n setInitialState({ ...initialState });\r\n }\r\n\r\n const handleChangeLang = (lang) => ()=>{\r\n initialState.currentLangSelected = lang;\r\n initialState.openLangMenu = false;\r\n inputRef.current.value = checkValue?.[lang] || checkValue?.[defaultLang];\r\n // if(ref && ref?.current){\r\n // ref.current.value = inputRef.current.value\r\n // }\r\n setInitialState({ ...initialState });\r\n setCurrentLang(lang);\r\n };\r\n\r\n\r\n return (\r\n \r\n
\r\n {icon || adornment ? (\r\n \r\n {icon ? (\r\n typeof icon !== \"string\" ? (\r\n icon\r\n ) : (\r\n \r\n )\r\n ) : adornment ? (\r\n {adornment} \r\n ) : null}\r\n
\r\n ) : null}\r\n {type === \"textarea\" ? (\r\n \r\n ) : (\r\n \r\n )}\r\n {!label ? null : (\r\n \r\n {label} \r\n \r\n )}\r\n {optionLang && Object.keys(optionLang)?.length ? (\r\n \r\n \r\n
\r\n {Object.keys(initialState.optionLang)\r\n .filter((item) => optionLang[item]?.blnActive || optionLang[item]?.blnIsActive)\r\n .map((item, index) => {\r\n return (\r\n \r\n }\r\n onClick={handleChangeLang(item)}\r\n >\r\n {initialState.optionLang[item]?.label || label?.[currentLang] || String(label)} \r\n \r\n );\r\n })}\r\n \r\n \r\n ) : endIcon || endAdornment ? (\r\n \r\n {endIcon ? (\r\n typeof endIcon !== \"string\" ? (\r\n endIcon\r\n ) : (\r\n \r\n )\r\n ) : endAdornment ? (\r\n {endAdornment} \r\n ) : null}\r\n
\r\n ) : null}\r\n \r\n {!MenuList ? null :
}\r\n
\r\n
{/* for style mnie list*/}\r\n
\r\n );\r\n});\r\n\r\nexport default GroupField;\r\n","import {\r\n StyleBuilder,\r\n styleVariables,\r\n cssKeys,\r\n mainTheme,\r\n styleFunction,\r\n } from \"@cbmisorg/styles\";\r\n \r\n export default(objThemeInfo)=>{\r\n const cssObject = objThemeInfo?.cssObject || mainTheme?.cssObject;\r\n const currentBaseSize = objThemeInfo?.currentBaseSize || mainTheme?.currentBaseSize;\r\n \r\n const classesName = {\r\n fieldset_comp_container: `${styleVariables?.prefixDefaultClassName}_fieldset_comp_container`,\r\n fieldset_container: `${styleVariables?.prefixDefaultClassName}_fieldset_container`,\r\n fieldset_input: `${styleVariables?.prefixDefaultClassName}_fieldset_input`,\r\n fieldset_label: `${styleVariables?.prefixDefaultClassName}_fieldset_label`,\r\n fieldset_label_text: `${styleVariables?.prefixDefaultClassName}_fieldset_label_text`,\r\n fieldset_icon: `${styleVariables?.prefixDefaultClassName}_fieldset_icon`,\r\n fieldset_front_icon: `${styleVariables?.prefixDefaultClassName}_fieldset_front_icon`,\r\n fieldset_end_icon: `${styleVariables?.prefixDefaultClassName}_fieldset_end_icon`,\r\n menuList:`${styleVariables?.prefixDefaultClassName}_fieldset_menuList`,\r\n menuLang:`${styleVariables?.prefixDefaultClassName}_fieldset_menuLang`,\r\n menuOptList:`${styleVariables?.prefixDefaultClassName}_fieldset_menuOptList`,\r\n\r\n inputValid: `${styleVariables?.prefixDefaultClassName}_inputValid`,\r\n \r\n sx:`${styleVariables?.prefixDefaultClassName}_input_sx`\r\n };\r\n \r\n const activeLabelPlace=(props)=>{\r\n return {\r\n [`.${classesName?.fieldset_label}`]:{\r\n position: cssObject?.position?.[cssKeys?.relative],\r\n top:0,\r\n fontSize:cssObject?.text?.[cssKeys?.size]?.body3,\r\n transform: `translateY(-${cssObject?.spacing?.[cssKeys?.md]})`,\r\n display:\"inline-grid\",\r\n }\r\n }\r\n }\r\n \r\n const style = StyleBuilder({\r\n blnRandomPrefix: false,\r\n blnIsDefaultStyle: true,\r\n blnCbmisStyle: true,\r\n objStyles: {\r\n [classesName?.fieldset_comp_container]:{\r\n display: cssObject?.display?.[cssKeys?.block],\r\n width: cssObject?.size?.[cssKeys?.full],\r\n minWidth: cssObject?.size?.[cssKeys?.full],\r\n position: cssObject?.position?.[cssKeys?.relative],\r\n margin:\"auto\",\r\n border:\"none\",\r\n outline:\"none\",\r\n height: \"auto\"\r\n },\r\n [classesName?.fieldset_container]:{\r\n display: cssObject?.display?.[cssKeys?.flex],\r\n width: \"auto\",\r\n position: cssObject?.position?.[cssKeys?.relative],\r\n margin:\"auto\",\r\n color: styleFunction.checkColorReturnValue(cssObject?.color?.[cssKeys?.currentColor]),\r\n flexBasis:\"100%\",\r\n height: \"auto\",\r\n alignItems:\"center\"\r\n \r\n },\r\n [classesName?.fieldset_input]:{\r\n width: cssObject?.size?.[cssKeys?.full],\r\n boxSizing: cssObject?.boxSizing?.[cssKeys?.borderBox],\r\n border:\"none\",\r\n outline:\"none\",\r\n background:\"transparent\",\r\n color: styleFunction.checkColorReturnValue(cssObject?.color?.[cssKeys?.currentColor]),\r\n height: \"auto\",\r\n },\r\n [classesName?.fieldset_label]:{\r\n position: cssObject?.position?.[cssKeys?.absolute],\r\n bottom: 0,\r\n left: 0,\r\n right: 0,\r\n top:\"15%\",\r\n display: cssObject?.display?.[cssKeys?.block],\r\n alignItems: cssObject?.flex?.[cssKeys?.baseline],\r\n pointerEvents: \"none\",\r\n textAlign:\"start\",\r\n height:\"0px\",\r\n width:\"fitContent\",\r\n margin:`0px`,\r\n padding:`0px`,\r\n transform: \"translateY(-50%)\",\r\n maxWidth: \"75%\",//`${currentBaseSize * 30}rem`,\r\n [`.${classesName?.fieldset_label_text}`]:{\r\n width:\"100%\",\r\n whiteSpace: \"nowrap\",\r\n overflow: \"hidden\",\r\n textOverflow: \"ellipsis\",\r\n display:\"inline-block\",\r\n padding:\"0\",\r\n margin:0,\r\n }\r\n\r\n },\r\n [classesName?.fieldset_icon]:{\r\n position: cssObject?.position?.[cssKeys?.relative],\r\n margin: cssObject?.spacing?.[cssKeys?.xs],\r\n display: cssObject?.display?.[cssKeys?.flex],\r\n alignItems:\"center\",\r\n justifyContent: \"center\"\r\n },\r\n [classesName?.menuLang]:{\r\n zIndex:\"10 !important\",\r\n maxHeight:`${currentBaseSize*80}rem !important`,\r\n position: \"fixed !important\",\r\n left: \"unset !important\",\r\n right: \"unset !important\",\r\n marginInlineStart:`-${currentBaseSize * 30}rem !important`,\r\n marginTop: \"0%\",\r\n minWidth: `${currentBaseSize * 30}rem !important`,\r\n maxWidth: `max-content !important`,\r\n overflow: \"hidden\"\r\n },\r\n },\r\n });\r\n \r\n \r\n const styleSx = StyleBuilder({\r\n blnRandomPrefix: true,\r\n blnIsDefaultStyle: false,\r\n blnCbmisStyle: true,\r\n objStyles: {\r\n [classesName?.fieldset_comp_container]:(props)=>{\r\n return{\r\n color: props?.errorMessage?styleFunction.checkColorReturnValue(cssObject?.color?.[cssKeys?.error]): styleFunction.checkColorReturnValue(cssObject?.color?.[cssKeys?.currentColor]),\r\n }\r\n },\r\n [classesName?.fieldset_container]:(props)=>{\r\n return{\r\n border: String(props.mode).toLowerCase() ===\"classic\"?\"none\": `${cssObject?.size?.[cssKeys?.border_xs]} ${cssObject?.border?.[cssKeys?.border]?.solid} ${styleFunction.checkColorReturnValue(cssObject?.color?.[cssKeys?.currentColor])}`,\r\n borderBottom: String(props.mode).toLowerCase() !==\"classic\"?\"\": `${cssObject?.size?.[cssKeys?.border_xs]} ${cssObject?.border?.[cssKeys?.border]?.solid} ${styleFunction.checkColorReturnValue(cssObject?.color?.[cssKeys?.currentColor])}`,\r\n minHeight: cssObject?.size?.[cssKeys?.item_md],\r\n borderRadius: cssObject?.border?.[cssKeys?.rounded]?.xs,\r\n cursor: props?.menuList? \"pointer\":\"\"\r\n\r\n }\r\n },\r\n [classesName?.fieldset_input]:(props)=>{\r\n return{\r\n width: cssObject?.size?.[cssKeys?.full],\r\n fontSize:cssObject?.text?.[cssKeys?.size]?.body2,\r\n padding:`${cssObject?.spacing?.[cssKeys?.xs]}`,\r\n minHeight: cssObject?.size?.[cssKeys?.item_md],\r\n cursor: props?.menuList? \"pointer\":\"\",\r\n color: cssObject?.color?.[cssKeys?.currentColor],\r\n direction: props?.inputDir || \"\",\r\n \"&focus\":String(props.mode).toLowerCase() === \"outlined\"?null:{\r\n \"&+\":activeLabelPlace(props)\r\n },\r\n \"¬PlaceholderShown\":String(props.mode).toLowerCase() === \"outlined\"?null:{\r\n \"&+\":activeLabelPlace(props)\r\n },\r\n \"&placeholderShown\":String(props.mode).toLowerCase() === \"outlined\" || !props?.placeholder?null:{\r\n \"&+\":activeLabelPlace(props)\r\n },\r\n }\r\n },\r\n [classesName?.fieldset_label]:(props)=>{\r\n return{\r\n fontSize:cssObject?.text?.size?.[cssKeys?.body2],\r\n color: styleFunction.checkColorReturnValue(cssObject?.color?.[cssKeys?.currentColor]),\r\n padding:props?.icon || props?.adornment? `${cssObject?.spacing?.[cssKeys?.px]} ${cssObject?.spacing?.[cssKeys?.xs]}`:`${cssObject?.spacing?.[cssKeys?.px]}`,\r\n marginInlineStart: (props?.icon || props?.adornment) && String(props.mode).toLowerCase() !== \"outlined\"? cssObject?.size?.[cssKeys?.item_xs]: cssObject?.spacing?.[cssKeys?.xs],\r\n [`.${classesName?.fieldset_label_text}`]:{\r\n // padding: `0 ${cssObject?.spacing?.[cssKeys?.xs]}`,\r\n // margin: `0 ${cssObject?.spacing?.[cssKeys?.sm]}`,\r\n\r\n }\r\n }\r\n \r\n },\r\n [classesName?.fieldset_icon]:(props)=>{\r\n return{\r\n color: styleFunction.checkColorReturnValue(props?.iconColor || cssObject?.color?.[cssKeys?.currentColor]),\r\n display: \"flex\",\r\n // height: cssObject?.size?.[cssKeys?.item_sm],\r\n height:\"100%\",\r\n alignItems: \"center\",\r\n padding: `0 ${cssObject?.spacing?.[cssKeys?.px]}`,\r\n }\r\n },\r\n [classesName?.fieldset_front_icon]:(props)=>{\r\n return{\r\n fontSize:props?.adornment ? cssObject?.text?.size?.[cssKeys?.caption]:cssObject?.text?.size?.[cssKeys?.subtitle1],\r\n // borderInlineEnd: props?.adornment || props?.icon ? `${cssObject?.size?.[cssKeys?.border_2xs]} ${cssObject?.border?.[cssKeys?.border]?.solid} ${styleFunction.checkColorReturnValue(cssObject?.color?.[cssKeys?.borderColor])}`:\"\"\r\n }\r\n },\r\n [classesName?.fieldset_end_icon]:(props)=>{\r\n return{\r\n fontSize:props?.endAdornment ? cssObject?.text?.size?.[cssKeys?.caption]:cssObject?.text?.size?.[cssKeys?.subtitle1],\r\n borderInlineStart: props?.endAdornment || props?.endIcon ?`${cssObject?.size?.[cssKeys?.border_2xs]} ${cssObject?.border?.[cssKeys?.border]?.solid} ${styleFunction.checkColorReturnValue(cssObject?.color?.[cssKeys?.borderColor])}`:\"\",\r\n }\r\n },\r\n [classesName?.menuList]:(props)=>{\r\n return{\r\n maxHeight:`${currentBaseSize*80}rem`,\r\n overflow:\"hidden\",\r\n }\r\n },\r\n [classesName?.menuOptList]:(props)=>{\r\n return{\r\n position: cssObject?.position?.[cssKeys?.relative],\r\n maxHeight:\"inherit\",\r\n overflowY:\"auto\",\r\n overflowX:\"hidden\",\r\n width:\"100%\"\r\n }\r\n },\r\n [classesName.sx]: (props) => {\r\n return{\r\n ... props?.sx,\r\n }\r\n }\r\n }\r\n });\r\n \r\n return{\r\n classesName,\r\n style,\r\n styleSx,\r\n }\r\n }","import React, { forwardRef } from \"react\";\r\nimport GroupField from \"../GroupField/GroupField\";\r\n\r\n\r\nconst DatePicker = forwardRef((/**@type= {any} */props, ref) => {\r\n const {type=\"date\",endIcon,onMouseOver,onBlur,defaultValue,value, ...rest} = props\r\n // const [theType, setTheType] = useState(\"text\");\r\n \r\n // const handleOnMouseOver=(event)=>{\r\n // if(theType === \"text\"){\r\n // setTheType(type || \"date\")\r\n // }\r\n // if(onMouseOver){\r\n // onMouseOver(event)\r\n // }\r\n // }\r\n\r\n // const handleBlur=(event)=>{\r\n // if(!event.target.value){\r\n // setTheType(\"text\")\r\n // }\r\n // if(onBlur){\r\n // onBlur(event)\r\n // }\r\n // }\r\n\r\n return (\r\n setTheType(type || \"date\"), onMouseLeave:() => setTheType(\"text\"), onTouchEnd:() => setTheType(type ===\"text\"?type || \"date\":\"text\"),}}\r\n {...rest}\r\n />\r\n )\r\n});\r\n\r\nexport default DatePicker","import React, { forwardRef, useContext, useEffect, useId } from \"react\";\r\nimport { styleFunction, ContextThemeProvider } from \"@cbmisorg/styles\";\r\nimport RadioButtonsStyle from \"./RadioButtonsStyle\";\r\nimport ErrorMessage from \"../ErrorMessage/ErrorMessage\";\r\nimport { checkParseObject } from \"../../_helper/functions\";\r\nimport ErrorBoundary from \"../../_helper/errorHandeling/ErrorBoundary/ErrorBoundary\";\r\n\r\nconst RadioButtons = forwardRef((/**@type {any}*/ props, ref) => {\r\n const {\r\n label,\r\n currentLang,\r\n options,\r\n children,\r\n display,\r\n color,\r\n sx,\r\n hidden,\r\n disabled,\r\n dir,\r\n value = null,\r\n defaultValue = null,\r\n className,\r\n id,\r\n filterValue,\r\n blnMenuInputList = false,\r\n errorMessage,\r\n helperMessage,\r\n ...rest\r\n } = props;\r\n const comID = id || String(useId()).slice(1, -1) + \"radio\";\r\n const theTheme = useContext(ContextThemeProvider);\r\n const { classesName, style, styleSx } = RadioButtonsStyle(theTheme);\r\n const classes = style();\r\n const classesSx = styleSx({ sx, color, display, blnMenuInputList });\r\n const itemClasses = styleFunction.getClassName(\r\n classes?.[classesName?.radio_container],\r\n classesSx?.[classesName?.radio_container],\r\n classesSx?.[classesName?.sx],\r\n styleFunction.CheckDirectionItem(dir),\r\n styleFunction.CheckDisabledItem(disabled),\r\n styleFunction.CheckHiddenItem(hidden),\r\n styleFunction.checkExistsMargin(rest),\r\n styleFunction.checkExistsPadding(rest),\r\n className\r\n );\r\n\r\n const RadioButtonsComp = () => {\r\n let lstOptions = [];\r\n if (children) {\r\n lstOptions = children;\r\n } else if (options) {\r\n lstOptions = options;\r\n }\r\n return (\r\n \r\n {!label ? null :
{label} }\r\n {lstOptions?.map((opt, index) => {\r\n const optValue = props?.blnMenuInputList\r\n ? value && typeof value === \"object\"\r\n ? checkParseObject(value)\r\n : defaultValue && typeof defaultValue === \"object\"\r\n ? checkParseObject(defaultValue)\r\n : value || defaultValue || {}\r\n : checkParseObject(value || defaultValue || {});\r\n\r\n return (\r\n
\r\n \r\n \r\n \r\n {opt?.props?.children || opt?.props?.value || typeof opt?.jsx === \"function\" ? opt?.jsx() : typeof opt?.value !== \"object\" ? opt?.value : opt?.value?.[currentLang] || \"\"}\r\n \r\n
\r\n \r\n );\r\n })}\r\n
\r\n
\r\n );\r\n };\r\n\r\n useEffect(() => {}, [\r\n label,\r\n currentLang,\r\n options,\r\n children,\r\n display,\r\n color,\r\n sx,\r\n hidden,\r\n disabled,\r\n dir,\r\n value,\r\n defaultValue,\r\n className,\r\n id,\r\n filterValue,\r\n blnMenuInputList,\r\n errorMessage,\r\n helperMessage,\r\n ]);\r\n\r\n return (\r\n \r\n \r\n \r\n \r\n );\r\n});\r\n\r\nexport default RadioButtons;\r\n","import { StyleBuilder, styleVariables, cssKeys, mainTheme, styleFunction } from \"@cbmisorg/styles\";\r\n\r\nexport default (objThemeInfo) => {\r\n const cssObject = objThemeInfo?.cssObject || mainTheme?.cssObject;\r\n const currentBaseSize = objThemeInfo?.currentBaseSize || mainTheme?.currentBaseSize;\r\n\r\n const classesName = {\r\n radio_container: `${styleVariables?.prefixDefaultClassName}_radio_container`,\r\n radio: `${styleVariables?.prefixDefaultClassName}_radio`,\r\n radio_opt_label: `${styleVariables?.prefixDefaultClassName}_radio_opt_label`,\r\n radio_opt: `${styleVariables?.prefixDefaultClassName}_radio_opt`,\r\n radio_label: `${styleVariables?.prefixDefaultClassName}_radio_label`,\r\n sx: `${styleVariables?.prefixDefaultClassName}_radio_sx`,\r\n };\r\n const style = StyleBuilder({\r\n blnRandomPrefix: false,\r\n blnIsDefaultStyle: true,\r\n blnCbmisStyle: true,\r\n objStyles: {\r\n [classesName?.radio_container]: {\r\n position: \"relative\",\r\n width: \"100%\",\r\n margin: 0,\r\n display: \"inline-block\",\r\n },\r\n [classesName?.radio]: {\r\n appearance: \"none\",\r\n WebkitAppearance: \"none\",\r\n /* remove default */\r\n display: \"flex\",\r\n alignSelf: \"flex-start\",\r\n position: \"relative\",\r\n borderRadius: cssObject?.border?.[cssKeys?.rounded]?.pill,\r\n cursor: \"pointer\",\r\n verticalAlign: \"middle\",\r\n boxShadow: \"0 0 0 1px rgba(0, 0, 0, 0.1)\",\r\n backgroundColor: cssObject?.color?.[cssKeys?.light],\r\n WebkitTransition: \"background-position .15s cubic-bezier(.8, 0, 1, 1), -webkit-transform .25s cubic-bezier(.8, 0, 1, 1)\",\r\n outline: \"none\",\r\n margin: 0,\r\n top: \".7rem\",\r\n \"&active\": {\r\n WebkitTransform: \"scale(1.5)\",\r\n WebkitTransition: \"-webkit-transform .1s cubic-bezier(0, 0, .2, 1)\",\r\n },\r\n },\r\n [classesName?.radio_label]: {\r\n display: \"flex\",\r\n alignItems: \"center\",\r\n fontWeight:\"600\",\r\n fontSize:cssObject?.text?.size?.[cssKeys?.subtitle3],\r\n textAlign: \"start\",\r\n width:\"100%\"\r\n },\r\n [classesName?.radio_opt]: {\r\n display: \"flex\",\r\n width: \"inherit\",\r\n justifyContent: \"flex-start\",\r\n alignItems: \"baseline\",\r\n // flexWrap: \"wrap\",\r\n },\r\n [classesName?.radio_opt_label]: {\r\n display: \"inline-block\",\r\n width: \"max-content\",\r\n margin: \"0px\"\r\n },\r\n },\r\n });\r\n\r\n const styleSx = StyleBuilder({\r\n blnRandomPrefix: true,\r\n blnIsDefaultStyle: false,\r\n blnCbmisStyle: true,\r\n objStyles: {\r\n [classesName?.radio_container]: (props) => {\r\n return {\r\n padding: `${cssObject?.spacing?.[cssKeys?.px]}`,\r\n margin:\"auto\",\r\n display: `${String(props?.display).toLowerCase() === \"inline\" && !props?.blnMenuInputList ? \"flex\" : \"block\"}`,\r\n width: props?.blnMenuInputList ? \"99%\" : \"maxContent\",\r\n // flexWrap: \"wrap\",\r\n };\r\n },\r\n [classesName?.radio]: (props) => {\r\n return {\r\n minWidth: props?.blnMenuInputList ? 0 : cssObject?.size?.[cssKeys?.item_2xs],\r\n width: props?.blnMenuInputList ? 0 : cssObject?.size?.[cssKeys?.item_2xs],\r\n height: props?.blnMenuInputList ? 0 : cssObject?.size?.[cssKeys?.item_2xs],\r\n opacity: props?.blnMenuInputList ? 0 : 1,\r\n \"&hover\": {\r\n backgroundColor: cssObject?.color?.[`${cssKeys?.primary}_1`],\r\n ...props?.sx?.[\"&hover\"],\r\n },\r\n \"&checked\": {\r\n WebkitTransition: \"background-position .1s .15s cubic-bezier(0, 0, .2, 1),-webkit-transform .25s cubic-bezier(0, 0, .2, 1)\",\r\n backgroundImage: `-webkit-radial-gradient( ${styleFunction?.checkColorReturnValue(props?.color || cssObject?.color?.[`${cssKeys?.primary}_1`])} 0%, ${styleFunction?.checkColorReturnValue(\r\n props?.color || cssObject?.color?.[`${cssKeys?.primary}_3`]\r\n )} 20%, ${styleFunction?.checkColorReturnValue(`${props?.color || cssObject?.color?.[`${cssKeys?.primary}_5`]}f5`)} 30%, ${styleFunction?.checkColorReturnValue(\r\n `${props?.color || cssObject?.color?.[`${cssKeys?.primary}`]}63`\r\n )} 70%)`,\r\n backgroundRepeat: \"no-repeat\",\r\n boxShadow: `0 0 0 0.05em ${cssObject?.color?.[cssKeys?.white]}, 0 0 0.15em 0.1em ${cssObject?.color?.[cssKeys?.primary]}`,\r\n ...props?.sx?.[\"&checked\"],\r\n \"&+\": props?.blnMenuInputList\r\n ? {\r\n [`.${classesName?.radio_opt_label}`]: {\r\n backgroundColor: cssObject?.color?.[`${cssKeys?.primary}_1`],\r\n color: cssObject?.color?.[cssKeys?.primary],\r\n },\r\n }\r\n : null,\r\n },\r\n };\r\n },\r\n [classesName?.radio_opt]: (props) => {\r\n return {\r\n color: cssObject?.color?.[cssKeys?.currentColor],\r\n fontSize: cssObject?.text?.size?.[cssKeys?.body3],\r\n margin: \"auto 0px\",\r\n // margin:String(props?.display).toLowerCase() === \"inline\"? `${cssObject?.spacing?.[cssKeys?.sm]}` : `${cssObject?.spacing?.[cssKeys?.sm]} ${cssObject?.spacing?.[cssKeys?.xs]}`,\r\n justlyContent: \"center\",\r\n alignItem: \"center\",\r\n textAlign: \"start\",\r\n width: props?.blnMenuInputList ? \"100%\" : \"inherit\",\r\n [`.${classesName?.radio_opt_label}`]: {\r\n padding:String(props?.display).toLowerCase() === \"inline\"? `${cssObject?.spacing?.[cssKeys?.sm]}`: `${cssObject?.spacing?.[cssKeys?.sm]} ${cssObject?.spacing?.[cssKeys?.sm]}`,\r\n fontSize: cssObject?.text?.size?.[cssKeys?.body3],\r\n ...(props?.blnMenuInputList\r\n ? {\r\n width: \"100%\",\r\n cursor: \"pointer\",\r\n \"&hover\": {\r\n backgroundColor: cssObject?.color?.[cssKeys?.light],\r\n },\r\n }\r\n : null),\r\n },\r\n };\r\n },\r\n [classesName?.radio_label]: {\r\n fontSize: cssObject?.text?.size?.[cssKeys?.subtitle3],\r\n textAlign: \"start\",\r\n maxWidth: \"fit-content\",\r\n margin: 0,\r\n },\r\n [classesName?.sx]: (props) => {\r\n return {\r\n ...props?.sx,\r\n };\r\n },\r\n },\r\n });\r\n\r\n return {\r\n classesName,\r\n style,\r\n styleSx,\r\n };\r\n};\r\n","// @ts-nocheck\r\nimport React, { forwardRef, useEffect, useRef, useState } from 'react'\r\nimport Menu from '../../navigation/Menu/Menu';\r\nimport RadioButtons from '../RadioButtons/RadioButtons';\r\nimport GroupField from '../GroupField/GroupField.js';\r\nimport { checkParseObject } from '../../_helper/functions';\r\n\r\n\r\nconst List = forwardRef((/**@type {any}*/props, ref) => {\r\n const {children,defaultValue=null,value=null,options=[],autocomplete,endIcon,onFocus,onChange,...rest} = props\r\n const refRadioValue = useRef({})\r\n\r\n const [initialState, setInitialState] = useState({\r\n openMenu:false,\r\n filterValue :\"\"\r\n })\r\n\r\n const handleFocus=(event)=>{\r\n initialState.openMenu= true;\r\n setInitialState({...initialState})\r\n if(onFocus){\r\n onFocus(event)\r\n }\r\n }\r\n const handleChange=(event)=>{\r\n refRadioValue.current={key:event?.target?.id,value:event?.target?.value}\r\n initialState.openMenu= false;\r\n initialState.filterValue=\"\";\r\n setInitialState({...initialState})\r\n if(onChange){\r\n onChange(event)\r\n }\r\n }\r\n \r\n const eventCloseMenu = () => {\r\n if(initialState.openMenu){\r\n initialState.openMenu= false;\r\n initialState.filterValue=\"\";\r\n setInitialState({...initialState})\r\n }\r\n \r\n }\r\n\r\n const MenuList =({comID,classes,classesName,currentLang})=> {return(\r\n \r\n \r\n \r\n
\r\n\r\n {\r\n // \r\n // \r\n }\r\n \r\n )}\r\n \r\n useEffect(() => {\r\n if(value || defaultValue){\r\n const theValue = checkParseObject(value || defaultValue);\r\n if(!theValue?.key){\r\n const indexValue = options.findIndex(item=>String(item.key) === String(theValue))\r\n refRadioValue.current =checkParseObject(options[indexValue])\r\n }else{\r\n refRadioValue.current = checkParseObject(theValue)\r\n }\r\n setInitialState({...initialState})\r\n }\r\n\r\n }, [value || defaultValue])\r\n\r\n return (\r\n \r\n \r\n \r\n )\r\n});\r\n\r\nexport default List","// @ts-nocheck\r\nimport React, { forwardRef, useMemo, useRef, useState } from 'react'\r\nimport Menu from '../../navigation/Menu/Menu';\r\nimport CheckboxGroup from '../CheckboxGroup/CheckboxGroup';\r\nimport GroupField from '../GroupField/GroupField.js';\r\nimport { checkParseObject } from '../../_helper/functions';\r\nimport { useEffect } from 'react';\r\n\r\n\r\nconst MultipleList = forwardRef((/**@type {any}*/props, ref) => {\r\n const {children,defaultValue,value,options=[],autocomplete,endIcon,onFocus,onChange,...rest} = props\r\n const refListKey = useRef([])\r\n const refListValue = useRef([])\r\n\r\n\r\n const [initialState, setInitialState] = useState({\r\n openMenu:false,\r\n filterValue :\"\"\r\n })\r\n\r\n const handleFocus=(event)=>{\r\n initialState.openMenu= !initialState.openMenu;\r\n setInitialState({...initialState})\r\n if(onFocus){\r\n onFocus(event)\r\n }\r\n }\r\n const handleChange=(event)=>{\r\n const checkValue ={key:event?.target?.id,value:event?.target?.value}\r\n if(!(refListKey.current.includes(String(checkValue?.key))) && !(refListKey.current.includes(checkValue?.key))){\r\n refListKey.current=[...refListKey.current,checkValue?.key];\r\n refListValue.current.push(checkValue?.value)\r\n }else{\r\n refListKey.current = refListKey?.current?.filter(item=> item !== String(checkValue?.key))\r\n refListValue.current = refListValue?.current?.filter(item=> item !== String(checkValue?.value))\r\n \r\n }\r\n\r\n // console.log(event.target.checked, refListKey.current, !(refListKey.current.includes(String(checkValue?.key))) && !(refListKey.current.includes(checkValue?.key)));\r\n\r\n // // initialState.openMenu= false;\r\n // initialState.filterValue=\"\";\r\n // inputRef.current.value= event?.target?.value || refRadioValue.current?.value || null\r\n // if(event?.target?.checked || refListKey.current.includes(event?.target?.id) || refListKey.current.includes(String(event?.target?.id))){\r\n // refListKey.current = refListKey?.current?.filter(item=> item !== String(event?.target?.id))\r\n // refListValue.current = refListValue?.current?.filter(item=> item !== event?.target?.value)\r\n // }else{\r\n // refListKey.current.push(event?.target?.id);\r\n // refListValue.current.push(event?.target?.value)\r\n // }\r\n\r\n\r\n \r\n if(onChange){\r\n onChange(event)\r\n }else{\r\n setInitialState({...initialState})\r\n }\r\n }\r\n \r\n const eventCloseMenu = () => {\r\n // inputRef?.current.blur();\r\n initialState.openMenu= false;\r\n initialState.filterValue=\"\";\r\n setInitialState({...initialState})\r\n }\r\n\r\n// useEffect(() => {\r\n// if(value || defaultValue){\r\n// const refCheckValue =checkParseObject(value || defaultValue)\r\n// refListKey.current = []\r\n// refListValue.current = []\r\n// // refCheckValue?.forEach(item=>{\r\n// // refListKey.current.push(String(item.key))\r\n// // refListValue.current.push(item.value)\r\n// // })\r\n// setInitialState({...initialState})\r\n// }\r\n// }, [value, defaultValue, options])\r\n\r\n useEffect(() => {\r\n if(value || defaultValue){\r\n const checkValue =checkParseObject(value || defaultValue)\r\n refListKey.current = []\r\n refListValue.current = []\r\n checkValue?.forEach(item=>{\r\n refListKey.current.push(String(item.key))\r\n refListValue.current.push(item.value)\r\n })\r\n setInitialState({...initialState})\r\n }\r\n }, [defaultValue,value])\r\n \r\n\r\n useEffect(() => {\r\n }, [children,options,autocomplete,endIcon,onFocus,onChange,rest])\r\n\r\n const MenuList =({comID,classes,classesName,currentLang}) =>{\r\n return(\r\n \r\n \r\n \r\n
\r\n \r\n {\r\n // \r\n // \r\n }\r\n \r\n )}\r\n \r\n return (\r\n \r\n )\r\n});\r\n\r\nexport default MultipleList","import React, { forwardRef, useContext, useId, useRef} from 'react'\r\nimport { ContextThemeProvider, cssKeys, mainTheme, styleFunction} from \"@cbmisorg/styles\";\r\nimport { Icon } from '@cbmisorg/icons';\r\nimport TextStyle from './TextStyle';\r\nimport ErrorMessage from '../ErrorMessage/ErrorMessage';\r\nimport GroupField from '../GroupField/GroupField';\r\n\r\nconst Text = forwardRef((/**@type {any}*/props, ref) => {\r\n // const {\r\n // id, label,placeholder,errorMessage=null, helperMessage, language=\"eng\",\r\n // icon,adornment,endIcon,endAdornment,\r\n // mode,color,iconColor,\r\n // type=\"text\",value=\"\",defaultValue=\"\",\r\n // inputDir,\r\n // onFocus, onBlur,\r\n // objLang,currentLang,setCurrentLang, getCurrentValue, // FORM API\r\n // sx,hidden,disabled,dir,className,MenuList=null,...rest} = props\r\n\r\n const {objLang,...rest} = props\r\n\r\n return (\r\n \r\n )\r\n});\r\n\r\nexport default Text","import React, { forwardRef, useContext, useId, useRef} from 'react'\r\nimport GroupField from '../GroupField/GroupField';\r\n\r\nconst TextArea = forwardRef((/**@type {any}*/props, ref) => {\r\n // const {\r\n // id, label,placeholder,errorMessage=null, helperMessage, language=\"eng\",\r\n // icon,adornment,endIcon,endAdornment,\r\n // mode,color,iconColor,\r\n // type=\"TextArea\",value=\"\",defaultValue=\"\",\r\n // inputDir,\r\n // onFocus, onBlur,\r\n // objLang,currentLang,setCurrentLang, getCurrentValue, // FORM API\r\n // sx,hidden,disabled,dir,className,MenuList=null,...rest} = props\r\n\r\n const {objLang,...rest} = props\r\n return (\r\n \r\n )\r\n});\r\n\r\nexport default TextArea","var __WEBPACK_NAMESPACE_OBJECT__ = require(\"@babel/runtime/helpers/objectDestructuringEmpty\");","import React, { forwardRef, useRef, useState } from \"react\";\r\nimport GroupField from \"../GroupField/GroupField\";\r\n\r\n\r\nconst Password = forwardRef((props, ref) => {\r\n const {...rest} = props\r\n const [type, setType] = useState(\"password\");\r\n\r\n\r\n return (\r\n setType(\"text\"), onMouseLeave:() => setType(\"password\"), onTouchEnd:() => setType(type ===\"text\"?\"password\":\"text\"),}}\r\n {...rest}\r\n />\r\n )\r\n});\r\n\r\nexport default Password","import React, { forwardRef, useEffect, useRef, useState } from \"react\";\r\nimport { styleFunction } from \"@cbmisorg/styles\";\r\nimport {Icon} from \"@cbmisorg/icons\";\r\nimport Text from \"../Text/Text\";\r\n\r\n\r\nconst Number = forwardRef((props, ref) => {\r\n const {defaultValue, max=100,min=0,step=1,setValue,...rest} = props\r\n\r\n const [theValue, setTheValue] = useState(defaultValue || \"\");\r\n\r\n\r\n const handleAdd = (event) => {\r\n let newValue = theValue\r\n if(!newValue){\r\n newValue = parseInt(max) || 0;\r\n }\r\n const theStep =parseInt(step);\r\n if(newValue < max){\r\n newValue = parseInt(newValue) + theStep;\r\n }else if(!max && parseInt(min) !== 0){\r\n newValue = parseInt(newValue) + theStep;\r\n }\r\n if(newValue > max){\r\n newValue = max\r\n }\r\n setTheValue(newValue);\r\n };\r\n\r\n const handleMinus = (event) => {\r\n let newValue = theValue\r\n\r\n if(!newValue){\r\n newValue = parseInt(min) || 0;\r\n }\r\n const theStep =parseInt(step);\r\n if(newValue > min){\r\n newValue = parseInt(newValue) - theStep;\r\n }else if(!min && parseInt(min) !== 0){\r\n newValue = parseInt(newValue) - theStep;\r\n }\r\n if(newValue < min){\r\n newValue = min\r\n }\r\n setTheValue(newValue);\r\n };\r\n\r\n useEffect(()=>{\r\n if(setValue && theValue){\r\n setValue(theValue);\r\n }\r\n // eslint-disable-next-line react-hooks/exhaustive-deps\r\n },[theValue])\r\n\r\n\r\n return (\r\n \r\n \r\n \r\n \r\n }\r\n {...rest}\r\n />\r\n )\r\n});\r\n\r\nexport default Number","import React, { forwardRef } from \"react\";\r\nimport { Icon } from \"@cbmisorg/icons\";\r\nimport { styleFunction } from \"@cbmisorg/styles\";\r\n\r\nconst RatingRadioInput = forwardRef((props, ref) => {\r\n const { name, id, value, icon, iconSize, readOnly, classes, classesSx, classesName,color,inputValue, ...rest } = props;\r\n\r\n return (\r\n \r\n \r\n \r\n = Number(value)? styleFunction.checkColorReturnValue(color || \"primary\"):null}/>\r\n \r\n \r\n );\r\n});\r\n\r\nexport default RatingRadioInput;\r\n","import React, { forwardRef, useContext, useId, useState } from \"react\";\r\nimport { ContextThemeProvider, styleFunction } from \"@cbmisorg/styles\";\r\nimport RatingStyle from \"./RatingStyle\";\r\nimport ErrorBoundary from \"../../_helper/errorHandeling/ErrorBoundary/ErrorBoundary\";\r\nimport RatingRadioInput from \"./RatingRadioInput\";\r\nimport ErrorMessage from \"../ErrorMessage/ErrorMessage\";\r\n\r\nconst Rating = forwardRef((/**@type {any}*/ props, ref) => {\r\n const theTheme = useContext(ContextThemeProvider);\r\n const { classesName, style, styleSx } = RatingStyle(theTheme);\r\n const { id, label, errorMessage, helperMessage, currentLang, color, icon, iconSize, value, defaultValue, onChange, readOnly = false, sx, hidden, disabled, dir, className, ...rest } = props;\r\n const classes = style();\r\n const classesSx = styleSx({ sx, color, readOnly });\r\n const comID = id || String(useId()).slice(1, -1) + \"rating\";\r\n const [inputValue, setInputValue] = useState(Number(value) || Number(defaultValue) || 0);;\r\n const itemClasses = styleFunction.getClassName(\r\n classes?.[classesName?.rating_container],\r\n classesSx?.[classesName?.sx],\r\n styleFunction.CheckDirectionItem(dir),\r\n styleFunction.CheckDisabledItem(disabled),\r\n styleFunction.CheckHiddenItem(hidden),\r\n styleFunction.checkExistsMargin(rest),\r\n styleFunction.checkExistsPadding(rest),\r\n className\r\n );\r\n\r\n //#region change\r\n const handleChange = (event) => {\r\n const id = String(event.target.id).split(\"-\");\r\n const value = parseInt(id[0].charAt(id[0].length - 1));\r\n if (onChange) {\r\n onChange(event);\r\n }\r\n setInputValue(value);\r\n };\r\n //#endregion\r\n\r\n return (\r\n \r\n
\r\n \r\n {label ? (\r\n \r\n {typeof label === \"object\" ? label?.[currentLang || \"default\"] : label}\r\n \r\n ) : (\r\n \"\"\r\n )}\r\n \r\n \r\n \r\n \r\n \r\n
\r\n \r\n
\r\n
\r\n );\r\n});\r\n\r\nexport default Rating;\r\n","import { StyleBuilder, styleVariables, cssKeys, mainTheme, styleFunction } from \"@cbmisorg/styles\";\r\n\r\nexport default (objThemeInfo) => {\r\n const cssObject = objThemeInfo?.cssObject || mainTheme?.cssObject;\r\n\r\n const classesName = {\r\n rating_container: `${styleVariables?.prefixDefaultClassName}_rating_container`,\r\n rating: `${styleVariables?.prefixDefaultClassName}_rating`,\r\n label: `${styleVariables?.prefixDefaultClassName}_label`,\r\n rating_input: `${styleVariables?.prefixDefaultClassName}_rating_input`,\r\n star: `${styleVariables?.prefixDefaultClassName}_star`,\r\n sx: `${styleVariables?.prefixDefaultClassName}_rating_sx`,\r\n };\r\n\r\n const style = StyleBuilder({\r\n blnRandomPrefix: false,\r\n blnIsDefaultStyle: true,\r\n blnCbmisStyle: true,\r\n objStyles: {\r\n [classesName?.rating_container]: {\r\n display: cssObject?.display?.[cssKeys?.block],\r\n boxSizing: cssObject?.boxSizing?.[cssKeys?.borderBox],\r\n position: cssObject?.position?.[cssKeys?.relative],\r\n margin: \"auto\",\r\n minHeight: \"max-content\",\r\n width: \"max-content\",\r\n maxWidth: cssObject?.size?.[cssKeys?.full],\r\n },\r\n [classesName?.label]: {\r\n display: \"flex\",\r\n alignItems: \"center\",\r\n fontWeight: \"600\",\r\n },\r\n [classesName.rating]: {\r\n display: \"cssObject?.display?.[cssKeys?.flex]\",\r\n flexWrap: \"nowrap\",\r\n alignItems: \"center\",\r\n justifyContent: \"space-around\",\r\n margin: `auto ${cssObject?.spacing?.[cssKeys?.sm]}`,\r\n overflow: \"hidden\",\r\n padding: 0,\r\n },\r\n [classesName.rating_input]: {\r\n opacity: 0,\r\n position: cssObject?.position?.[cssKeys?.relative],\r\n maxWidth: cssObject?.size?.[cssKeys?.px],\r\n margin: 0,\r\n padding: 0,\r\n },\r\n [classesName?.star]: {\r\n color: cssObject?.color?.[cssKeys?.bodyColor],\r\n textDecoration: \"none\",\r\n WebkitTransition: \" color .4s\",\r\n MozTransition: \" color .4s\",\r\n OTransition: \" color .4s\",\r\n transition: \" color .4s\",\r\n display: \"inline-flex\",\r\n },\r\n },\r\n });\r\n\r\n const styleSx = StyleBuilder({\r\n blnRandomPrefix: true,\r\n blnIsDefaultStyle: false,\r\n blnCbmisStyle: true,\r\n objStyles: {\r\n [classesName?.label]: {\r\n fontSize: cssObject?.text?.size?.[cssKeys?.subtitle3],\r\n textAlign: \"start\",\r\n maxWidth: \"fit-content\",\r\n margin: 0,\r\n },\r\n [classesName?.star]: (props) => {\r\n return {\r\n fontSize: cssObject?.text?.size?.[cssKeys?.h6],\r\n \"&hover\": props.readOnly\r\n ? null\r\n : {\r\n cursor: \"pointer\",\r\n opacity: 0.7,\r\n color: styleFunction.checkColorReturnValue(props?.color || props?.sx?.color || \"primary\"),\r\n },\r\n };\r\n },\r\n [classesName?.sx]: (props) => {\r\n return props?.sx;\r\n },\r\n },\r\n });\r\n\r\n return {\r\n classesName,\r\n style,\r\n styleSx,\r\n };\r\n};\r\n","import { ContextThemeProvider, styleFunction } from '@cbmisorg/styles';\r\nimport React, { useEffect, useRef } from 'react'\r\nimport { useContext } from 'react';\r\nimport { forwardRef } from 'react';\r\nimport { useId } from 'react';\r\nimport RangeSliderStyle from './RangeSliderStyle';\r\n\r\nconst RangeSlider = forwardRef((/**@type {any}*/props, ref) => {\r\n const {id,label,errorMessage,helperMessage,\r\n color,currentLang,readOnly,\r\n value,defaultValue, showMaxMin=true, showValue=true,\r\n min=0,max=100, step=1, thumb=true, gauge=\"%\",\r\n sx,hidden,disabled,dir,className,...rest} = props\r\n const comID = String(useId()).slice(1,-1) + \"checkbox\" || id;\r\n const theTheme = useContext(ContextThemeProvider);\r\n const {classesName, style, styleSx} = RangeSliderStyle(theTheme);\r\n const classes = style();\r\n const classesSx = styleSx({sx, color,thumb, showMaxMin, showValue, readOnly});\r\n const itemClasses = styleFunction.getClassName(classes?.[classesName?.range_slider],classesSx?.[classesName?.range_slider], classesSx?.[classesName?.sx], className);\r\n const containerClasses = styleFunction.getClassName(classes?.[classesName?.range_container], styleFunction.CheckDirectionItem(dir),styleFunction.CheckDisabledItem(disabled), styleFunction.CheckHiddenItem(hidden),styleFunction.checkExistsMargin(rest),styleFunction.checkExistsPadding(rest));\r\n\r\n const inputRef = useRef({})\r\n\r\n useEffect(()=>{\r\n // inputRef.current.value = value || defaultValue || 0\r\n // if(ref){\r\n // ref.current.value = value || defaultValue || 0\r\n // }\r\n // setInputValue({\r\n // ...inputValue,\r\n // value: ref?.current?.value || inputRef.current.value || 0,\r\n // })\r\n\r\n },[value, defaultValue])\r\n\r\n return (\r\n \r\n {\r\n // !showValue?null:(\r\n //
\r\n // \r\n //
\r\n // )\r\n }\r\n {\r\n !showValue?null:(\r\n
\r\n {parseInt(value || defaultValue)}{gauge}\r\n \r\n )\r\n }\r\n
{label} \r\n
\r\n {\r\n // !showValue?null:(\r\n //
\r\n // {ref?.current?.value || inputRef?.current?.value}{gauge}\r\n // \r\n // )\r\n }\r\n {!showMaxMin ? null:(\r\n
\r\n {min || min ===0 ? {min} : \"\"}\r\n {max ? {max} : \"\"}\r\n
\r\n )}\r\n
\r\n )\r\n});\r\n\r\nexport default RangeSlider","import {\r\n StyleBuilder,\r\n styleVariables,\r\n cssKeys,\r\n mainTheme,\r\n styleFunction,\r\n} from \"@cbmisorg/styles\";\r\n\r\nexport default(objThemeInfo)=>{\r\n const cssObject = objThemeInfo?.cssObject || mainTheme?.cssObject;\r\n const currentBaseSize = objThemeInfo?.currentBaseSize || mainTheme?.currentBaseSize;\r\n\r\n const classesName = {\r\n container: `${styleVariables?.prefixDefaultClassName}_container`,\r\n\r\n range_container: `${styleVariables?.prefixDefaultClassName}_range_container`,\r\n range_slider: `${styleVariables?.prefixDefaultClassName}_range_slider`,\r\n range_label: `${styleVariables?.prefixDefaultClassName}_range_label`,\r\n range_slider_min_max: `${styleVariables?.prefixDefaultClassName}_range_slider_min_max`,\r\n range_lider_tooltip: `${styleVariables?.prefixDefaultClassName}_range_lider_tooltip`,\r\n range_lider_tooltip_text: `${styleVariables?.prefixDefaultClassName}_range_lider_tooltip_text`,\r\n range_slider_value_output: `${styleVariables?.prefixDefaultClassName}_range_slider_value_output`,\r\n sx: `${styleVariables?.prefixDefaultClassName}_range_sx`,\r\n };\r\n const style = StyleBuilder({\r\n blnRandomPrefix: false,\r\n blnIsDefaultStyle: true,\r\n blnCbmisStyle: true,\r\n objStyles:{\r\n [classesName?.range_container]:{\r\n position: \"relative\",\r\n width: \"100%\",\r\n display:\"block\",\r\n margin:0,\r\n padding:0,\r\n },\r\n [classesName?.range_slider]:{\r\n position: \"relative\",\r\n width: \"100%\",\r\n display:\"flex\",\r\n margin:0,\r\n padding:0,\r\n appearance:\"none\",\r\n WebkitAppearance:\"none\",\r\n MozAppearance:\"none\",\r\n background: \"none\",\r\n alignSelf: \"center\",\r\n cursor: \"grab\",\r\n\r\n \"&focus\":{\r\n boxShadow: \"none\",\r\n outline: \"none\",\r\n },\r\n \"&WebkitSliderRunnableTrack\":{\r\n content: '',\r\n pointerEvents: \"none\",\r\n width: \"100%\",\r\n overflow:\"hidden\",\r\n zIndex:0,\r\n },\r\n \"&WebkitSliderThumb\": {\r\n appearance:\"none\",\r\n WebkitAppearance:\"none\",\r\n MozAppearance:\"none\",\r\n // borderRadius: \"50%\",\r\n width:\"100px\",\r\n height:\"100px\",\r\n backgroundColor: \"currentColor\",\r\n zIndex:2,\r\n padding:0,\r\n },\r\n \"&MozRangeTrack\":{\r\n width: \"100%\",\r\n },\r\n \"&MozRangeThumb\":{\r\n cursor: \"grab\",\r\n borderRadius: \"50%\",\r\n position: \"relative\",\r\n padding:0,\r\n },\r\n \"&MozRangeProgress\": {\r\n border: 0,\r\n marginTop: 0,\r\n },\r\n },\r\n [classesName?.range_label]:{\r\n display: \"flex\",\r\n },\r\n [classesName?.range_slider_min_max]:{\r\n display: \"flex\",\r\n justifyContent:\"space-between\",\r\n margin: 0,\r\n padding: 0,\r\n \"span\":{\r\n display: \"flex\",\r\n margin: 0,\r\n padding: 0,\r\n height: 0,\r\n lineHeight: \"1rem\",\r\n }\r\n },\r\n [classesName?.range_lider_tooltip]:{\r\n zIndex: 2,\r\n position: \"absolute\",\r\n textAlign: \"center\",\r\n opacity: 1,\r\n borderRadius: \"100%\",\r\n background:cssObject?.color?.[cssKeys?.currentColor],\r\n \"&after\":{\r\n content: \"\",\r\n position: \"absolute\",\r\n left: 0,\r\n borderTopColor: cssObject?.color?.[cssKeys?.currentColor],\r\n\r\n }\r\n },\r\n [classesName?.range_slider_value_output]:{\r\n position: \"absolute\",\r\n textAlign: \"center\",\r\n width:\"90%\"\r\n },\r\n }\r\n });\r\n\r\n const styleSx = StyleBuilder({\r\n blnRandomPrefix: true,\r\n blnIsDefaultStyle: false,\r\n blnCbmisStyle: true,\r\n objStyles: {\r\n [classesName?.range_slider]:(props) => {\r\n return{\r\n height: cssObject?.spacing?.[cssKeys?.sm], /* Specified height */\r\n background: cssObject?.color?.[cssKeys?.light],\r\n borderRadius: cssObject?.border?.[cssKeys?.rounded]?.md,\r\n transition: \"box-shadow 0.2s ease-in-out\",\r\n transformOrigin: \"75px 75px\",\r\n progressShadow: \"2px 2px 4px rgba(0, 0, 0, 0.2) inset\",\r\n pointerEvents: !props?.readOnly ? \"none\": \"default\",\r\n \"&WebkitSliderThumb\":{\r\n position:\"relative\",\r\n borderRadius: cssObject?.border?.[cssKeys?.rounded]?.md,\r\n padding:0,\r\n boxShadow: `-1000px 0 0 1000px ${ styleFunction.checkColorReturnValue(props?.color || cssObject?.color?.[cssKeys?.primary])}`,//cssObject?.boxShadow?.[cssKeys?.md],\r\n ...(\r\n props?.thumb?{\r\n height: cssObject?.spacing?.[cssKeys?.md],\r\n width: cssObject?.spacing?.[cssKeys?.md],\r\n cursor: \"grab\",\r\n border: `${cssObject?.size?.[cssKeys?.border_xs]} ${cssObject?.border?.[cssKeys?.border]?.solid} ${styleFunction.checkColorReturnValue(cssObject?.color?.[cssKeys?.light])}`,\r\n background: styleFunction.checkColorReturnValue(props?.color || cssObject?.color?.[cssKeys?.primary]), \r\n }:{\r\n height: 0,\r\n width: 0,\r\n cursor: \"none\",\r\n pointerEvents:\"none\",\r\n border:\"none\",\r\n }\r\n ),\r\n },\r\n \"&WebkitSliderRunnableTrack\":{\r\n background: cssObject?.color?.[cssKeys?.light],\r\n height: cssObject?.spacing?.[cssKeys?.sm],\r\n border: `${cssObject?.size?.[cssKeys?.border_xs]} ${cssObject?.border?.[cssKeys?.border]?.solid} ${styleFunction.checkColorReturnValue(props?.color || cssObject?.color?.[cssKeys?.primary])}`,\r\n },\r\n \"&MozRangeThumb\":{\r\n position:\"relative\",\r\n borderRadius: cssObject?.border?.[cssKeys?.rounded]?.[cssKeys?.md],\r\n ...(\r\n props?.thumb?{\r\n height: cssObject?.spacing?.[cssKeys?.md],\r\n width: cssObject?.spacing?.[cssKeys?.md],\r\n cursor: \"grab\",\r\n border: `${cssObject?.size?.[cssKeys?.border_xs]} ${cssObject?.border?.[cssKeys?.border]?.solid} ${styleFunction.checkColorReturnValue(cssObject?.color?.[cssKeys?.light])}`,\r\n background: styleFunction.checkColorReturnValue(props?.color || cssObject?.color?.[cssKeys?.primary]),\r\n }:{\r\n height: 0,\r\n width: 0,\r\n cursor: \"none\",\r\n border:\"none\",\r\n }\r\n ),\r\n },\r\n \"&MozRangeTrack\":{\r\n height: cssObject?.spacing?.[cssKeys?.sm],\r\n },\r\n \"&MozRangeProgress\": {\r\n height: cssObject?.spacing?.[cssKeys?.sm],\r\n background: styleFunction.checkColorReturnValue(props?.color || cssObject?.color?.[cssKeys?.primary]),\r\n },\r\n\r\n \"&MsTrack\": {\r\n height: cssObject?.spacing?.[cssKeys?.sm],\r\n border: `${cssObject?.size?.[cssKeys?.border_xs]} ${cssObject?.border?.[cssKeys?.border]?.solid} ${styleFunction.checkColorReturnValue(cssObject?.color?.[cssKeys?.primary])}`,\r\n },\r\n \"&MsFillLower\":{\r\n background: styleFunction.checkColorReturnValue(cssObject?.color?.[cssKeys?.primary]),\r\n },\r\n \"&MsFillUpper\": {\r\n background: styleFunction.checkColorReturnValue(cssObject?.color?.[cssKeys?.primary]),\r\n },\r\n }\r\n },\r\n [classesName?.range_lider_tooltip]:(props) =>{\r\n return{\r\n top: `-${cssObject?.size?.[cssKeys?.item_md]}`,\r\n width: cssObject?.size?.[cssKeys?.item_sm],\r\n height: cssObject?.size?.[cssKeys?.item_sm],\r\n color:props?.color? styleFunction?.checkColorReturnValue(props?.color) : cssObject?.color?.[cssKeys?.primary],\r\n \"&after\":{\r\n top: \"19px\",\r\n borderLeft: \"14px solid transparent\",\r\n borderRight: \"14px solid transparent\",\r\n borderTopWidth: \"16px\",\r\n borderTopStyle: \"solid\",\r\n borderRadius: \"16px\",\r\n }\r\n }\r\n },\r\n [classesName?.range_slider_value_output]:(props)=>{\r\n return{\r\n top: `-${cssObject?.size?.[cssKeys?.item_xs]}`,\r\n color:props?.color? styleFunction?.checkColorReturnValue(props?.color) : cssObject?.color?.[cssKeys?.primary],\r\n fontSize: cssObject?.text?.size?.[cssKeys?.subtitle2],\r\n }},\r\n [classesName?.sx]: (props) => {\r\n return {\r\n color:props?.color? styleFunction?.checkColorReturnValue(props?.color) : cssObject?.color?.[cssKeys?.primary],\r\n ...props?.sx,\r\n\r\n };\r\n },\r\n },\r\n });\r\n\r\n\r\n return{\r\n classesName,\r\n style,\r\n styleSx,\r\n }\r\n}","import { ContextThemeProvider, styleFunction } from '@cbmisorg/styles';\r\nimport React, { forwardRef, useContext, useId } from 'react'\r\nimport SwitchStyle from './SwitchStyle';\r\nimport ErrorMessage from '../ErrorMessage/ErrorMessage';\r\n\r\nconst Switch = forwardRef((/**@type {any}*/props, ref) => {\r\n const {id,label,errorMessage,helperMessage,\r\n color,currentLang,\r\n value,defaultValue=false,\r\n sx,hidden,disabled,dir,className,...rest} = props\r\n const comID = String(useId()).slice(1,-1) + \"checkbox\" || id;\r\n const theTheme = useContext(ContextThemeProvider);\r\n const {classesName, style, styleSx} = SwitchStyle(theTheme);\r\n const classes = style();\r\n const classesSx = styleSx({sx, color, dir});\r\n const itemClasses = styleFunction.getClassName(classes?.[classesName?.switch_container], classesSx?.[classesName?.sx], className);\r\n const itemClasses2 = styleFunction.getClassName(classes?.[classesName?.switch], styleFunction.CheckDirectionItem(dir),styleFunction.CheckDisabledItem(disabled), styleFunction.CheckHiddenItem(hidden),styleFunction.checkExistsMargin(rest),styleFunction.checkExistsPadding(rest));\r\n\r\n return (\r\n \r\n
\r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n {label?.[currentLang] || label}\r\n \r\n\r\n
\r\n
\r\n
\r\n\r\n )\r\n});\r\n\r\nexport default Switch","import {\r\n StyleBuilder,\r\n styleVariables,\r\n cssKeys,\r\n mainTheme,\r\n styleFunction,\r\n} from \"@cbmisorg/styles\";\r\n\r\nexport default(objThemeInfo)=>{\r\n const cssObject = objThemeInfo?.cssObject || mainTheme?.cssObject;\r\n const currentBaseSize = objThemeInfo?.currentBaseSize || mainTheme?.currentBaseSize;\r\n\r\n const classesName = {\r\n container: `${styleVariables?.prefixDefaultClassName}_main_switch_container`,\r\n\r\n switch_container: `${styleVariables?.prefixDefaultClassName}_switch_container`,\r\n switch: `${styleVariables?.prefixDefaultClassName}_switch`,\r\n switch_input: `${styleVariables?.prefixDefaultClassName}_switch_input`,\r\n switch_slider: `${styleVariables?.prefixDefaultClassName}_switch_slider`,\r\n switch_slider_toggle: `${styleVariables?.prefixDefaultClassName}_switch_slider_toggle`,\r\n switch_label: `${styleVariables?.prefixDefaultClassName}_switch_label`,\r\n sx: `${styleVariables?.prefixDefaultClassName}_switch_sx`,\r\n };\r\n const style = StyleBuilder({\r\n blnRandomPrefix: false,\r\n blnIsDefaultStyle: true,\r\n blnCbmisStyle: true,\r\n objStyles:{\r\n [classesName?.container]:{\r\n position: \"relative\", \r\n width: \"auto\",\r\n display:\"flex\",\r\n margin:\"0\",\r\n maxWidth:\"100%\"\r\n },\r\n [classesName?.switch_container]:{\r\n position: \"relative\", \r\n width: \"auto\",\r\n display:\"flex\",\r\n alignItems:\"center\",\r\n margin:\"0\",\r\n maxWidth:\"100%\"\r\n\r\n },\r\n [classesName?.switch]:{\r\n display: \"inline-block\",\r\n position:\"relative\",\r\n margin:\"0\"\r\n },\r\n [classesName?.switch_input]:{\r\n display: \"none\",\r\n \"&focus\":{\r\n \"&+\":{\r\n [`.${classesName?.switch_slider}`]:{\r\n boxShadow: \"0 0 0 1px rgba(0, 0, 0, 0.1)\",\r\n\r\n }\r\n }\r\n },\r\n },\r\n [classesName?.switch_label]:{\r\n display: \"block\",\r\n cursor: \"pointer\",\r\n position:\"relative\",\r\n },\r\n [classesName?.switch]:{\r\n display: \"inline-block\",\r\n position:\"relative\"\r\n },\r\n [classesName?.switch_slider]: {\r\n position: \"relative\",\r\n display:\"block\",\r\n border: 0,\r\n outline: \"none\",\r\n backgroundColor: \"#ccc\",\r\n transition: \".4s\",\r\n cursor: \"pointer\",\r\n padding:\"0px\",\r\n margin:\"auto 0\",\r\n },\r\n [classesName?.switch_slider_toggle]:{\r\n content: \"\",\r\n position: \"absolute\",\r\n display:\"block\",\r\n left: \"1px\",\r\n right: \"1px\",\r\n bottom: \"0px\",\r\n backgroundColor: \"#fff\",\r\n transition: \".4s\",\r\n borderRadius: \"50%\",\r\n margin:\"0\",\r\n }\r\n }\r\n });\r\n\r\n const styleSx = StyleBuilder({\r\n blnRandomPrefix: true,\r\n blnIsDefaultStyle: false,\r\n blnCbmisStyle: true,\r\n objStyles: {\r\n [classesName?.switch_input]:(props)=>{\r\n return { \r\n \"&checked\":{\r\n \"&+\":{\r\n [`.${classesName?.switch_slider}`]:{\r\n background:cssObject?.color?.[cssKeys?.currentColor],\r\n [`.${classesName?.switch_slider_toggle}`]:{\r\n transform:props?.dir === \"rtl\"?`translateX(-${cssObject?.size?.[cssKeys?.item_xs]})`: `translateX(${cssObject?.size?.[cssKeys?.item_xs]})`\r\n }\r\n }\r\n }\r\n }\r\n }\r\n },\r\n [classesName?.switch_label]:{\r\n margin:`auto ${cssObject?.spacing?.[cssKeys?.xs]}`,\r\n color:cssObject?.color?.[cssKeys?.bodyColor],\r\n fontSize:cssObject?.text?.size?.[cssKeys?.body2],\r\n padding: `0 ${cssObject?.spacing?.[cssKeys?.px]}`,\r\n },\r\n [classesName?.switch_slider]: {\r\n width: cssObject?.size?.[cssKeys?.item_lg],\r\n height: cssObject?.size?.[cssKeys?.item_xs],\r\n borderRadius: cssObject?.border?.[cssKeys?.rounded]?.xl,\r\n\r\n },\r\n [classesName?.switch_slider_toggle]:{\r\n height: `${currentBaseSize*5}rem`,\r\n width: `${currentBaseSize*5}rem`,\r\n top:`${currentBaseSize/2}rem`,\r\n },\r\n [classesName?.sx]: (props) => {\r\n return {\r\n color:props?.color? styleFunction?.checkColorReturnValue(props?.color) : cssObject?.color?.[cssKeys?.primary],\r\n ...props?.sx,\r\n\r\n };\r\n },\r\n },\r\n });\r\n\r\n\r\n return{\r\n classesName,\r\n style,\r\n styleSx,\r\n }\r\n}","import React, { forwardRef } from 'react'\r\n\r\n\r\nconst Option = forwardRef((/**@type {any}*/props, ref) => {\r\n const {children, rest} = props\r\n return (\r\n {children} \r\n )\r\n})\r\n\r\nexport default Option\r\n","import React, { useContext } from 'react'\r\nimport { ContextThemeProvider, styleFunction } from \"@cbmisorg/styles\";\r\nimport GridStyle from './GridStyle';\r\nimport ErrorBoundary from '../../_helper/errorHandeling/ErrorBoundary/ErrorBoundary';\r\n\r\nconst Grid = React?.forwardRef(function Grid(/**@type {any}*/props, ref) {\r\n const theTheme = useContext(ContextThemeProvider);\r\n const {getGridClassName, style, styleSx} = GridStyle(theTheme);\r\n\r\n const {\r\n container,\r\n item,\r\n xs,\r\n sm,\r\n md,\r\n lg,\r\n xl,\r\n spacing,\r\n alignContent,\r\n alignItems,\r\n alignSelf,\r\n justifyContent,\r\n direction,\r\n sx,\r\n hidden,\r\n disabled,\r\n dir,\r\n className,\r\n ...rest\r\n } = props;\r\n\r\n const classes = style()\r\n const classesSx = styleSx({ sx, container, item, xs, sm, md, lg, xl, spacing, alignItems,alignContent, alignSelf, justifyContent, direction });\r\n\r\n const itemClasses = styleFunction.getClassName(getGridClassName({container, item, classes, classesSx}), styleFunction.CheckDirectionItem(dir),styleFunction.CheckDisabledItem(disabled), styleFunction.CheckHiddenItem(hidden),styleFunction.checkExistsMargin(rest),styleFunction.checkExistsPadding(rest), className);\r\n\r\n return(\r\n \r\n {props?.children} \r\n
\r\n )\r\n});\r\n\r\nexport default Grid","import { StyleBuilder, styleVariables, cssKeys, mainTheme, sizeOneValueSetter, aggregationSizeStyle, sizeValuesSetter } from \"@cbmisorg/styles\";\r\n\r\nexport default (objThemeInfo) => {\r\n const cssObject = objThemeInfo?.cssObject || mainTheme?.cssObject;\r\n const currentBaseSize = objThemeInfo?.currentBaseSize || mainTheme?.currentBaseSize;\r\n\r\n const style = StyleBuilder({\r\n blnRandomPrefix: false,\r\n blnIsDefaultStyle: true,\r\n blnCbmisStyle: true,\r\n objStyles: {\r\n [`${styleVariables?.prefixDefaultClassName}_grid_container`]: {\r\n width: cssObject?.size?.[cssKeys?.full],\r\n flexWrap: \"wrap\",\r\n flexFlow: \"wrap\",\r\n margin: \"0 auto\",\r\n padding: 0,\r\n boxSizing: cssObject?.boxSizing?.[cssKeys?.borderBox],\r\n position: cssObject?.position?.[cssKeys?.relative],\r\n display: cssObject?.display?.[cssKeys?.flex],\r\n alignContent: \"flex-start\",\r\n alignItems: \"stretch\",\r\n justifyItems: \"stretch\",\r\n },\r\n [`${styleVariables?.prefixDefaultClassName}_grid_item`]: {\r\n margin: 0,\r\n flexWrap: \"wrap\",\r\n flexFlow: \"wrap\",\r\n justifyItems: \"stretch\",\r\n boxSizing: cssObject?.boxSizing?.[cssKeys?.borderBox],\r\n position: cssObject?.position?.[cssKeys?.relative],\r\n display: cssObject?.display?.[cssKeys?.flex],\r\n },\r\n },\r\n });\r\n\r\n const styleSx = StyleBuilder({\r\n blnRandomPrefix: true,\r\n blnIsDefaultStyle: false,\r\n blnCbmisStyle: true,\r\n objStyles: {\r\n [`${styleVariables?.prefixDefaultClassName}_grid`]: (props) => {\r\n let objsx = {};\r\n if (props?.item) {\r\n const result = sizeValuesSetter({ xs: props?.xs, sm: props?.sm, md: props?.md, lg: props?.lg, xl:props?.xl }, (size, styleValue) => {\r\n return {\r\n xl: getGridCol(styleValue),\r\n lg: getGridCol(styleValue),\r\n md: getGridCol(styleValue),\r\n sm: getGridCol(styleValue),\r\n xs: getGridCol(styleValue),\r\n default: getGridCol(null),\r\n }?.[size];\r\n }); \r\n\r\n \r\n let objColStyle = { ...getGridCol(null) };\r\n if (props?.xs) {\r\n objColStyle = {\r\n ...objColStyle,\r\n ...getGridCol(props?.xs),\r\n xs: {\r\n ...getGridCol(props?.xs),\r\n },\r\n };\r\n }\r\n if (props?.sm) {\r\n objColStyle = {\r\n ...objColStyle,\r\n ...getGridCol(props?.sm),\r\n sm: {\r\n ...getGridCol(props?.xs),\r\n },\r\n };\r\n }\r\n if (props?.md) {\r\n objColStyle = {\r\n ...objColStyle,\r\n ...getGridCol(props?.md),\r\n md: {\r\n ...getGridCol(props?.md),\r\n },\r\n };\r\n }\r\n if (props?.lg) {\r\n objColStyle = {\r\n ...objColStyle,\r\n ...getGridCol(props?.lg),\r\n lg: {\r\n ...getGridCol(props?.lg),\r\n },\r\n };\r\n }\r\n if (props?.xl) {\r\n objColStyle = {\r\n ...objColStyle,\r\n xl: {\r\n ...getGridCol(props?.xl),\r\n },\r\n };\r\n }\r\n objsx = aggregationSizeStyle(objColStyle,objsx);\r\n }\r\n if (props?.container) {\r\n const spacing = isNaN(parseInt(props?.spacing)) ? 1 : parseInt(props?.spacing);\r\n objsx = {\r\n ...objsx,\r\n \"&>\": {\r\n [`.${styleVariables?.prefixDefaultClassName}_grid_item`]: {\r\n padding: `${currentBaseSize * spacing}rem`,\r\n },\r\n },\r\n };\r\n }\r\n\r\n objsx = {\r\n fontSize: cssObject?.text?.size?.body1,\r\n color: cssObject?.color?.bodyColor,\r\n ...aggregationSizeStyle(\r\n sizeOneValueSetter(\"alignContent\", props?.alignContent),\r\n sizeOneValueSetter(\"alignItems\", props?.alignItems),\r\n sizeOneValueSetter(\"alignSelf\", props?.alignSelf),\r\n sizeOneValueSetter(\"justifyContent\", props?.justifyContent),\r\n sizeOneValueSetter(\"flexDirection\", props?.direction),\r\n objsx\r\n ),\r\n };\r\n\r\n return objsx;\r\n },\r\n [`${styleVariables?.prefixDefaultClassName}_grid_sx`]: (props) => {\r\n return {\r\n ...props?.sx,\r\n };\r\n },\r\n },\r\n });\r\n\r\n const getGridCol = (col) => {\r\n const gridCol = parseInt(col);\r\n switch (gridCol) {\r\n case 0:\r\n return {\r\n flexGrow: 0,\r\n width: \"0\",\r\n flexBasis: 0,\r\n display: \"none\",\r\n };\r\n case 1:\r\n return {\r\n flexGrow: 0,\r\n width: cssObject?.size?.[cssKeys?.[\"1/12\"]],\r\n flexBasis: cssObject?.size?.[cssKeys?.[\"1/12\"]],\r\n display: \"flex\",\r\n };\r\n case 2:\r\n return {\r\n flexGrow: 0,\r\n width: cssObject?.size?.[cssKeys?.[\"2/12\"]],\r\n flexBasis: cssObject?.size?.[cssKeys?.[\"2/12\"]],\r\n display: \"flex\",\r\n };\r\n case 3:\r\n return {\r\n flexGrow: 0,\r\n width: cssObject?.size?.[cssKeys?.[\"3/12\"]],\r\n flexBasis: cssObject?.size?.[cssKeys?.[\"3/12\"]],\r\n display: \"flex\",\r\n };\r\n case 4:\r\n return {\r\n flexGrow: 0,\r\n width: cssObject?.size?.[cssKeys?.[\"4/12\"]],\r\n flexBasis: cssObject?.size?.[cssKeys?.[\"4/12\"]],\r\n display: \"flex\",\r\n };\r\n case 5:\r\n return {\r\n flexGrow: 0,\r\n width: cssObject?.size?.[cssKeys?.[\"5/12\"]],\r\n flexBasis: cssObject?.size?.[cssKeys?.[\"5/12\"]],\r\n display: \"flex\",\r\n };\r\n case 6:\r\n return {\r\n flexGrow: 0,\r\n width: cssObject?.size?.[cssKeys?.[\"6/12\"]],\r\n flexBasis: cssObject?.size?.[cssKeys?.[\"6/12\"]],\r\n display: \"flex\",\r\n };\r\n case 7:\r\n return {\r\n flexGrow: 0,\r\n width: cssObject?.size?.[cssKeys?.[\"7/12\"]],\r\n flexBasis: cssObject?.size?.[cssKeys?.[\"7/12\"]],\r\n display: \"flex\",\r\n };\r\n case 8:\r\n return {\r\n flexGrow: 0,\r\n width: cssObject?.size?.[cssKeys?.[\"8/12\"]],\r\n flexBasis: cssObject?.size?.[cssKeys?.[\"8/12\"]],\r\n display: \"flex\",\r\n };\r\n case 9:\r\n return {\r\n flexGrow: 0,\r\n width: cssObject?.size?.[cssKeys?.[\"9/12\"]],\r\n flexBasis: cssObject?.size?.[cssKeys?.[\"9/12\"]],\r\n display: \"flex\",\r\n };\r\n case 10:\r\n return {\r\n flexGrow: 0,\r\n width: cssObject?.size?.[cssKeys?.[\"10/12\"]],\r\n flexBasis: cssObject?.size?.[cssKeys?.[\"10/12\"]],\r\n display: \"flex\",\r\n };\r\n case 11:\r\n return {\r\n flexGrow: 0,\r\n width: cssObject?.size?.[cssKeys?.[\"11/12\"]],\r\n flexBasis: cssObject?.size?.[cssKeys?.[\"11/12\"]],\r\n display: \"flex\",\r\n };\r\n case 12:\r\n return {\r\n flexGrow: 0,\r\n width: cssObject?.size?.[cssKeys?.full],\r\n flexBasis: cssObject?.size?.[cssKeys?.full],\r\n\r\n display: \"flex\",\r\n };\r\n default:\r\n return {\r\n flexGrow: 0,\r\n width: \"auto\",\r\n display: \"flex\",\r\n flexBasis: \"auto\",\r\n };\r\n }\r\n };\r\n\r\n const getGridClassName = ({ container, item, classes, classesSx }) => {\r\n const isContainer = container ? `${classes?.[`${styleVariables?.prefixDefaultClassName}_grid_container`]}` : \"\";\r\n const isItem = item ? `${classes?.[`${styleVariables?.prefixDefaultClassName}_grid_item`]}` : \"\";\r\n return `${isContainer} ${isItem} ${classesSx?.[`${styleVariables?.prefixDefaultClassName}_grid`]} ${classesSx?.[`${styleVariables?.prefixDefaultClassName}_grid_sx`]}`;\r\n };\r\n\r\n return {\r\n getGridClassName,\r\n style,\r\n styleSx,\r\n };\r\n};\r\n","import React, { useId, useRef } from \"react\";\r\nimport { ClassesBuilder } from \"@cbmisorg/styles\";\r\nimport { Grid } from \"../../index\";\r\nexport default function RadialProgressBar({ onChange = null, value = null, label = \" deg\", readOnly = false }) {\r\n let id = useId().replaceAll(\":\", \"\");\r\n const circleID = \"radial-slider-circle-\" + id;\r\n const dotCircleID = \"radial-slider-dot-circle-\" + id;\r\n const dotCircleClassName = \"radial-slider-dot-\" + id;\r\n const debugCircleID = \"radial-slider-debug-circle-\" + id;\r\n\r\n const style = ClassesBuilder({\r\n container: {\r\n border: \"0\",\r\n margin: \"0\",\r\n padding: \"0\",\r\n boxSizing: \"border-box\",\r\n outline: \"0\",\r\n WebkitUserSelect: \"none\",\r\n MozUserSelect: \"none\",\r\n msUserSelect: \"none\",\r\n userSelect: \"none\",\r\n height: \"100%\",\r\n width: \"100%\",\r\n \"&>\": {\r\n \"&*\": {\r\n WebkitUserSelect: \"none\",\r\n MozUserSelect: \"none\",\r\n msUserSelect: \"none\",\r\n userSelect: \"none\",\r\n border: \"0\",\r\n margin: \"0\",\r\n padding: \"0\",\r\n boxSizing: \"border-box\",\r\n outline: 0,\r\n },\r\n },\r\n },\r\n debug: {\r\n color: \"#2e78b2\",\r\n fontFamily: \"monospace\",\r\n position: \"absolute\",\r\n top: \"50%\",\r\n left: \"50%\",\r\n transform: \"translate3d(-50%, -50%, 0)\",\r\n zIndex: 100,\r\n fontSize: \"18px\",\r\n backgroundColor: \"#ecf0f1\",\r\n },\r\n circle: {\r\n position: \"relative\",\r\n top: \"50%\",\r\n left: \"50%\",\r\n backgroundColor: value && typeof value === \"number\" ? `conic-gradient(#FF3B60 0deg ${value}deg, #2e78b2 ${value + 1}deg ${360 - value}deg)` : \"#2e78b2\",\r\n borderRadius: \"50%\",\r\n width: \"25%\",\r\n height: \"0\",\r\n minWidth: \"50px\",\r\n minHeight: \"50px\",\r\n paddingBottom: \"25%\",\r\n transform: \"translate3d(-50%, -50%, 0)\",\r\n boxShadow: \"0 0 10px rgba(#000, 0.5)\",\r\n \"&before\": {\r\n content: \"''\",\r\n position: \"absolute\",\r\n width: \"90%\",\r\n height: \"90%\",\r\n backgroundColor: \"#ecf0f1\",\r\n borderRadius: \"50%\",\r\n top: \"5%\",\r\n left: \"5%\",\r\n boxShadow: \"inset 0 0 10px rgba(#000, 0.5)\",\r\n },\r\n [\".\" + dotCircleClassName]: {\r\n position: \"absolute\",\r\n width: \"5%\",\r\n height: \"50%\",\r\n left: \"47.5%\",\r\n top: \"0\",\r\n transform: value && typeof value === \"number\" ? `rotate(${value}deg)` : \"rotate(0deg)\",\r\n transformOrigin: \"center bottom\",\r\n \"&before\": {\r\n content: \"''\",\r\n position: \"absolute\",\r\n backgroundColor: \"#fff\",\r\n boxShadow: \"0 0 10px #000\",\r\n width: \"200%\",\r\n transform: \"translate3d(-25%, -25%, 0)\",\r\n height: \"0\",\r\n paddingBottom: \"200%\",\r\n borderRadius: \"50%\",\r\n cursor: \"pointer\",\r\n },\r\n },\r\n },\r\n });\r\n\r\n const inputRef = useRef({ isDragging: false, value: value });\r\n\r\n const onDrag = (event) => {\r\n try {\r\n event.preventDefault();\r\n\r\n if (!inputRef?.current?.isDragging || readOnly) {\r\n return;\r\n }\r\n\r\n let circle = document.getElementById(circleID);\r\n\r\n let rect = circle.getBoundingClientRect();\r\n\r\n let center_x = rect?.width / 2 + rect?.left;\r\n let center_y = rect?.height / 2 + rect?.top;\r\n\r\n let touch = null;\r\n if (circle?.originalEvent && circle?.originalEvent.touches) {\r\n touch = circle?.originalEvent.touches[0];\r\n }\r\n\r\n let pos_x = event?.pageX || touch?.pageX;\r\n let pos_y = event?.pageY || touch?.pageY;\r\n\r\n let delta_y = center_y - pos_y;\r\n let delta_x = center_x - pos_x;\r\n let angle = Math.atan2(delta_y, delta_x) * (180 / Math.PI);\r\n\r\n angle = angle - 90;\r\n\r\n if (angle < 0) {\r\n angle = 360 + angle;\r\n }\r\n\r\n angle = Math.round(angle);\r\n inputRef.current.value = angle;\r\n if (onChange) {\r\n onChange({ ...event, value: angle });\r\n }\r\n\r\n circle.style.background = `conic-gradient(#FF3B60 0deg ${angle}deg, #2e78b2 ${angle + 1}deg ${360 - angle}deg)`;\r\n\r\n let dotEle = document.getElementById(dotCircleID);\r\n if (dotEle) {\r\n dotEle.style.transform = `rotate(${angle}deg)`;\r\n }\r\n let debugEle = document.getElementById(debugCircleID);\r\n if (debugEle) {\r\n debugEle.innerHTML = angle + label;\r\n }\r\n } catch {}\r\n };\r\n\r\n const onDragStart = (event) => {\r\n inputRef.current.isDragging = true;\r\n };\r\n\r\n const onDragEnd = (event) => {\r\n inputRef.current.isDragging = false;\r\n };\r\n\r\n return (\r\n <>\r\n \r\n \r\n \r\n
\r\n
\r\n {value || inputRef.current.value || 0}\r\n {label}\r\n
\r\n {readOnly ? null :
}\r\n
\r\n
\r\n \r\n \r\n >\r\n );\r\n}\r\n","import React, { forwardRef, useContext } from \"react\";\r\nimport { ContextThemeProvider, styleFunction } from \"@cbmisorg/styles\";\r\nimport BoxStyle from \"./BoxStyle\";\r\nimport ErrorBoundary from \"../../_helper/errorHandeling/ErrorBoundary/ErrorBoundary\";\r\n\r\nconst Box = forwardRef((/**@type {any}*/props, ref) => {\r\n const theTheme = useContext(ContextThemeProvider);\r\n const {classesName, style, styleSx} = BoxStyle(theTheme);\r\n const { color=null, outline=0, elevation=0, hoverElevation=0, sx = null, hidden=false, disabled=false, dir=null, className=null, id=null, ...rest } = props;\r\n const classes = style();\r\n const classesSx = styleSx({ sx ,outline, elevation, hoverElevation, color});\r\n const itemClasses = styleFunction.getClassName(classes?.[classesName?.box], classesSx?.[classesName?.sx], styleFunction.CheckDirectionItem(dir),styleFunction.CheckDisabledItem(disabled), styleFunction.CheckHiddenItem(hidden),styleFunction.checkExistsMargin(rest),styleFunction.checkExistsPadding(rest), className);\r\n\r\n\r\n return (\r\n \r\n {props.children} \r\n
\r\n );\r\n});\r\n\r\nexport default Box;\r\n","import {\r\n StyleBuilder,\r\n styleVariables,\r\n cssKeys,\r\n mainTheme,\r\n styleFunction,\r\n} from \"@cbmisorg/styles\";\r\n\r\n\r\nexport default(objThemeInfo)=>{\r\n const cssObject = objThemeInfo?.cssObject || mainTheme?.cssObject;\r\n\r\n const classesName = {\r\n box: `${styleVariables?.prefixDefaultClassName}_box`,\r\n sx: `${styleVariables?.prefixDefaultClassName}_box_sx`,\r\n };\r\n\r\n const style = StyleBuilder({\r\n blnRandomPrefix: false,\r\n blnIsDefaultStyle: true,\r\n blnCbmisStyle: true,\r\n objStyles: {\r\n [classesName?.box]: {\r\n display: \"block\",\r\n position: \"relative\",\r\n overflow: \"auto\",\r\n width: cssObject?.size?.[cssKeys?.full],\r\n maxWidth: cssObject?.size?.[cssKeys?.full],\r\n textAlign: \"center\",\r\n color: cssObject?.color?.bodyColor,\r\n }\r\n },\r\n });\r\n\r\n const styleSx = StyleBuilder({\r\n blnRandomPrefix: true,\r\n blnIsDefaultStyle: false,\r\n blnCbmisStyle: true,\r\n objStyles: {\r\n [classesName?.sx]: (props) => {\r\n return {\r\n fontSize:cssObject?.text?.size?.body1,\r\n padding: cssObject?.spacing?.[cssKeys?.md],\r\n margin: `${cssObject?.spacing?.[cssKeys?.sm]} auto`,\r\n borderRadius: cssObject?.border?.[cssKeys?.rounded]?.sm,\r\n ...getBorder(props),\r\n boxShadow:getShadow(props?.elevation),\r\n ...props?.sx,\r\n \"&hover\":{\r\n cursor:parseInt(props?.hoverElevation)?\"pointer\":\"default\",\r\n ...props?.sx?.[\"&hover\"],\r\n boxShadow:getShadow(props?.hoverElevation)\r\n }\r\n };\r\n },\r\n },\r\n });\r\n\r\n const getBorder = (props) => {\r\n switch (parseInt(props?.outline)) {\r\n case 1:\r\n return {\r\n color: styleFunction.checkColorReturnValue(props?.color || cssObject?.color?.bodyColor),\r\n border: `${cssObject?.size?.[cssKeys?.border_xs]} ${cssObject?.border?.[cssKeys?.border]?.solid} ${styleFunction.checkColorReturnValue(props?.color || cssObject?.color?.bodyColor)}`,\r\n background: cssObject?.color?.[cssKeys?.transparent],\r\n };\r\n case 2:\r\n return {\r\n color: styleFunction.checkColorReturnValue(props?.color || cssObject?.color?.bodyColor),\r\n border: `${cssObject?.size?.[cssKeys?.border_sm]} ${cssObject?.border?.[cssKeys?.border]?.solid} ${styleFunction.checkColorReturnValue(props?.color ||cssObject?.color?.bodyColor)}`,\r\n background: cssObject?.color?.[cssKeys?.transparent],\r\n };\r\n case 3:\r\n return {\r\n color: props?.color || cssObject?.color?.bodyColor,\r\n border: `${cssObject?.size?.[cssKeys?.border_md]} ${cssObject?.border?.[cssKeys?.border]?.solid} ${props?.color ||cssObject?.color?.bodyColor}`,\r\n background: cssObject?.color?.[cssKeys?.transparent],\r\n };\r\n case 4:\r\n return {\r\n color: styleFunction.checkColorReturnValue(props?.color || cssObject?.color?.bodyColor),\r\n border: `${cssObject?.size?.[cssKeys?.border_lg]} ${cssObject?.border?.[cssKeys?.border]?.solid} ${styleFunction.checkColorReturnValue(props?.color ||cssObject?.color?.bodyColor)}`,\r\n background: cssObject?.color?.[cssKeys?.transparent],\r\n };\r\n case 5:\r\n return {\r\n color: styleFunction.checkColorReturnValue(props?.color || cssObject?.color?.bodyColor),\r\n border: `${cssObject?.size?.[cssKeys?.border_xl]} ${cssObject?.border?.[cssKeys?.border]?.solid} ${styleFunction.checkColorReturnValue(props?.color ||cssObject?.color?.bodyColor)}`,\r\n background: cssObject?.color?.[cssKeys?.transparent],\r\n };\r\n case 0:\r\n return {\r\n color: styleFunction.checkColorReturnValue(cssObject?.color?.bodyColor),\r\n background: styleFunction.checkColorReturnValue(props?.color || cssObject?.color?.primary),\r\n };\r\n default:\r\n return {\r\n color: styleFunction.checkColorReturnValue(props?.color || cssObject?.color?.bodyColor),\r\n border: `${cssObject?.size?.[cssKeys?.border_xs]} ${cssObject?.border?.[cssKeys?.border]?.solid} ${styleFunction.checkColorReturnValue(props?.color || cssObject?.color?.bodyColor)}`,\r\n background: cssObject?.color?.[cssKeys?.transparent],\r\n\r\n };\r\n }\r\n };\r\n\r\n const getShadow = (elevation) => {\r\n switch (parseInt(elevation || 0)) {\r\n case 1:\r\n return cssObject?.boxShadow?.[cssKeys?.xs];\r\n case 2:\r\n return cssObject?.boxShadow?.[cssKeys?.sm];\r\n case 3:\r\n return cssObject?.boxShadow?.[cssKeys?.md];\r\n case 4:\r\n return cssObject?.boxShadow?.[cssKeys?.lg];\r\n case 5:\r\n return cssObject?.boxShadow?.[cssKeys?.xl];\r\n default:\r\n return cssObject?.boxShadow?.[cssKeys?.xs];\r\n }\r\n };\r\n\r\n return{\r\n classesName,\r\n style,\r\n styleSx,\r\n }\r\n}","import React, { forwardRef, useContext} from \"react\";\r\nimport { ContextThemeProvider, styleFunction } from \"@cbmisorg/styles\";\r\nimport ContainerStyle from \"./ContainerStyle\";\r\nimport ErrorBoundary from \"../../_helper/errorHandeling/ErrorBoundary/ErrorBoundary\";\r\n\r\nconst Container = forwardRef((/**@type {any}*/props, ref) => {\r\n const theTheme = useContext(ContextThemeProvider);\r\n const {classesName, style, styleSx} = ContainerStyle(theTheme);\r\n const { width, sx, hidden, disabled, dir, className, ...rest } = props;\r\n const classes = style();\r\n const classesSx = styleSx({sx, width});\r\n\r\n const itemClasses = styleFunction.getClassName(\r\n classes?.[classesName?.drawer],\r\n classesSx?.[classesName?.drawer],\r\n classesSx?.[classesName?.sx],\r\n styleFunction.CheckDirectionItem(dir),\r\n styleFunction.CheckDisabledItem(disabled),\r\n styleFunction.CheckHiddenItem(hidden),\r\n styleFunction.checkExistsMargin(rest),\r\n styleFunction.checkExistsPadding(rest),\r\n className\r\n );\r\n return (\r\n \r\n {props.children} \r\n
\r\n );\r\n});\r\n\r\nexport default Container;","import {\r\n StyleBuilder,\r\n styleVariables,\r\n cssKeys,\r\n mainTheme,\r\n} from \"@cbmisorg/styles\";\r\n\r\n\r\nexport default(objThemeInfo)=>{\r\n const cssObject = objThemeInfo?.cssObject || mainTheme?.cssObject;\r\n\r\n const classesName = {\r\n container: `${styleVariables?.prefixDefaultClassName}_container`,\r\n sx:`${styleVariables?.prefixDefaultClassName}_container_sx`\r\n }\r\n\r\n const style = StyleBuilder({\r\n blnRandomPrefix: false,\r\n blnIsDefaultStyle: true,\r\n blnCbmisStyle: true,\r\n objStyles: {\r\n [classesName?.container]: {\r\n display: cssObject?.display?.[cssKeys?.block],\r\n boxSizing: cssObject?.boxSizing?.[cssKeys?.borderBox],\r\n position:cssObject?.position?.[cssKeys?.relative],\r\n margin: \"auto\",\r\n height:\"fit-content\",\r\n }\r\n },\r\n });\r\n\r\n const styleSx = StyleBuilder({\r\n blnRandomPrefix: true,\r\n blnIsDefaultStyle: false,\r\n blnCbmisStyle: true,\r\n objStyles: {\r\n [classesName?.sx]: (props) => {\r\n return {\r\n padding: cssObject?.spacing?.[cssKeys?.xs],\r\n borderRadius: cssObject?.border?.[cssKeys?.rounded]?.xs,\r\n width: getWidth(props?.width)?.width,\r\n height:\"fit-content\",\r\n ...props?.sx,\r\n sm:{\r\n width: getWidth(props?.width)?.sm?.width,\r\n padding: cssObject?.spacing?.[cssKeys?.xs],\r\n height:\"fit-content\",\r\n ...props?.sx?.sm,\r\n },\r\n xs:{\r\n width: cssObject?.size?.[cssKeys?.full],\r\n padding: cssObject?.spacing?.[cssKeys?.px],\r\n height:\"fit-content\",\r\n ...props?.sx?.sm,\r\n },\r\n };\r\n },\r\n },\r\n });\r\n\r\n const getWidth = (width) => {\r\n switch (String(width).toLowerCase()) {\r\n case \"xl\":\r\n return {\r\n width: cssObject?.size?.[cssKeys?.xl]\r\n }\r\n case \"lg\":\r\n return {\r\n width: cssObject?.size?.[cssKeys?.lg]\r\n }\r\n case \"md\":\r\n return {\r\n width: cssObject?.size?.[cssKeys?.md]\r\n }\r\n case \"sm\":\r\n return {\r\n width: cssObject?.size?.[cssKeys?.sm]\r\n }\r\n case \"xm\":\r\n return {\r\n width: cssObject?.size?.[cssKeys?.xs]\r\n }\r\n case \"fluid\":\r\n return {\r\n width: cssObject?.size?.[cssKeys?.full]\r\n }\r\n case \"half\":\r\n return {\r\n width: cssObject?.size?.[cssKeys?.half]\r\n }\r\n default:\r\n return {\r\n width: cssObject?.size?.[cssKeys?.[\"11/12\"]],\r\n sm:{\r\n width: cssObject?.size?.[cssKeys?.[\"12/12\"]],\r\n padding:cssObject?.spacing?.[cssKeys?.xs]\r\n }\r\n }\r\n }\r\n };\r\n\r\n return{\r\n classesName,\r\n style,\r\n styleSx,\r\n }\r\n}","import React, { useContext } from \"react\";\r\nimport { ContextThemeProvider, styleFunction } from \"@cbmisorg/styles\";\r\nimport LineStyle from \"./LineStyle\";\r\nimport ErrorBoundary from \"../../_helper/errorHandeling/ErrorBoundary/ErrorBoundary\";\r\n\r\nconst Line = React?.forwardRef(function Line (/**@type {any}*/props, ref) {\r\n const theTheme = useContext(ContextThemeProvider);\r\n const {classesName, style, styleSx} = LineStyle(theTheme);\r\n const { sx, color, hidden, disabled, dir, className, label, mode, ...rest } = props;\r\n const classes = style();\r\n const classesSx = styleSx({sx,color,mode});\r\n\r\n const itemClasses = styleFunction.getClassName(classes?.[classesName?.line_container], classesSx?.[classesName?.sx], styleFunction.CheckDirectionItem(dir),styleFunction.CheckDisabledItem(disabled), styleFunction.CheckHiddenItem(hidden),styleFunction.checkExistsMargin(rest),styleFunction.checkExistsPadding(rest), className);\r\n\r\n return(\r\n \r\n
\r\n {label ?
{label} : \"\"}\r\n
\r\n )\r\n});\r\n\r\nexport default Line","import {\r\n StyleBuilder,\r\n styleVariables,\r\n cssKeys,\r\n mainTheme,\r\n styleFunction,\r\n} from \"@cbmisorg/styles\";\r\n\r\n\r\nexport default(objThemeInfo)=>{\r\n const cssObject = objThemeInfo?.cssObject || mainTheme?.cssObject;\r\n\r\n const classesName = {\r\n line_container: `${styleVariables?.prefixDefaultClassName}_line_container`,\r\n line_label: `${styleVariables?.prefixDefaultClassName}_line_Label`,\r\n line: `${styleVariables?.prefixDefaultClassName}_line`,\r\n line_fade: `${styleVariables?.prefixDefaultClassName}_line_fade`,\r\n sx:`${styleVariables?.prefixDefaultClassName}_line_sx`\r\n };\r\n\r\n const style = StyleBuilder({\r\n blnRandomPrefix: false,\r\n blnIsDefaultStyle: true,\r\n blnCbmisStyle: true,\r\n objStyles: {\r\n [classesName?.line_container]:{\r\n display: cssObject?.size?.[cssKeys?.flex],\r\n justifyContent: \"center\",\r\n position:cssObject?.position?.[cssKeys?.relative],\r\n alignItems: \"center\",\r\n flexWrap: \"wrap\",\r\n width: \"95%\",\r\n [`.${classesName?.line_label}`]:{\r\n position:cssObject?.position?.[cssKeys?.absolute],\r\n top: \"-50%\",\r\n left: \"50%\",\r\n transform: \"translateX(-50%) translateY(-50%)\",\r\n color: cssObject?.color?.currentColor,\r\n },\r\n [`.${classesName?.line}`]:{\r\n display: cssObject?.size?.[cssKeys?.flex],\r\n position:cssObject?.position?.[cssKeys?.relative],\r\n height: cssObject?.spacing?.[cssKeys?.xs],\r\n padding: \"0px\",\r\n margin:\"auto\",\r\n outline: \"none\",\r\n border: \"none\",\r\n flex:1,\r\n backgroundColor: cssObject?.color?.currentColor,\r\n\r\n },\r\n [`.${classesName?.line_fade}`]:{\r\n background: `linear-gradient(to left, ${cssObject?.color?.transparent}, ${cssObject?.color?.currentColor}, ${cssObject?.color?.transparent})`,\r\n },\r\n },\r\n },\r\n });\r\n\r\n const styleSx = StyleBuilder({\r\n blnRandomPrefix: true,\r\n blnIsDefaultStyle: false,\r\n blnCbmisStyle: true,\r\n objStyles: {\r\n [classesName?.sx]: (props) => {\r\n return {\r\n color: styleFunction.checkColorReturnValue(props?.color || cssObject?.color?.borderColor),\r\n fontSize:cssObject?.text?.size?.[cssKeys?.subtitle2],\r\n [`.${classesName?.line_label}`]:{\r\n padding: `0 ${cssObject?.spacing?.[cssKeys?.sm]}`,\r\n background: cssObject?.color?.bodyColorBg,\r\n },\r\n [`.${classesName?.line}`]:{\r\n height: cssObject?.spacing?.[cssKeys?.[\"3xs\"]],\r\n },\r\n ...props?.sx,\r\n };\r\n },\r\n },\r\n });\r\n\r\n return{\r\n classesName,\r\n style,\r\n styleSx,\r\n }\r\n}","import React, { forwardRef, useContext } from \"react\";\r\nimport { ContextThemeProvider, styleFunction } from \"@cbmisorg/styles\";\r\nimport BreadcrumbsStyle from \"./BreadcrumbsStyle\";\r\nimport ErrorBoundary from \"../../_helper/errorHandeling/ErrorBoundary/ErrorBoundary\";\r\n\r\nconst Breadcrumbs = forwardRef((/**@type {any}*/ props, ref) => {\r\n const theTheme = useContext(ContextThemeProvider);\r\n const { classesName, style, styleSx } = BreadcrumbsStyle(theTheme);\r\n const { separator, breadcrumbs, color, sx, hidden, disabled, dir, className, id, ...rest } = props;\r\n const classes = style();\r\n const classesSx = styleSx({ sx, separator, breadcrumbs, color });\r\n\r\n const itemClasses = styleFunction.getClassName(\r\n classes?.[classesName?.breadcrumbs],\r\n classesSx?.[classesName?.sx],\r\n styleFunction.CheckDirectionItem(dir),\r\n styleFunction.CheckDisabledItem(disabled),\r\n styleFunction.CheckHiddenItem(hidden),\r\n styleFunction.checkExistsMargin(rest),\r\n styleFunction.checkExistsPadding(rest),\r\n className\r\n );\r\n\r\n return (\r\n \r\n \r\n {breadcrumbs && breadcrumbs.length > 0\r\n ? breadcrumbs.map((item, index) => {\r\n return (\r\n {}}>\r\n \r\n {!item?.icon ? null : item?.icon}\r\n {!item?.label ? null : item?.label}\r\n \r\n {item?.blnSeparator === false ? null : {separator ? separator : \"/\"} }\r\n \r\n );\r\n })\r\n : \"\"}\r\n \r\n \r\n );\r\n});\r\n\r\nexport default Breadcrumbs;\r\n","import {\r\n StyleBuilder,\r\n styleVariables,\r\n cssKeys,\r\n mainTheme,\r\n styleFunction,\r\n} from \"@cbmisorg/styles\";\r\n\r\nexport default(objThemeInfo)=>{\r\n const cssObject = objThemeInfo?.cssObject || mainTheme?.cssObject;\r\n\r\n const classesName = {\r\n breadcrumbs: `${styleVariables?.prefixDefaultClassName}_breadcrumbs`,\r\n breadcrumbs_item: `${styleVariables?.prefixDefaultClassName}_breadcrumbs_item`,\r\n breadcrumbs_item_hover: `${styleVariables?.prefixDefaultClassName}_breadcrumbs_item_hover`,\r\n breadcrumbs_item_last: `${styleVariables?.prefixDefaultClassName}_breadcrumbs_item_last`,\r\n breadcrumbs_separator: `${styleVariables?.prefixDefaultClassName}_breadcrumbs_separator`,\r\n\r\n sx:`${styleVariables?.prefixDefaultClassName}_breadcrumbs_sx`\r\n }\r\n\r\n const style = StyleBuilder({\r\n blnRandomPrefix: false,\r\n blnIsDefaultStyle: true,\r\n blnCbmisStyle: true,\r\n objStyles: {\r\n [classesName?.breadcrumbs]: {\r\n display: cssObject?.display?.[cssKeys?.flex],\r\n margin: `0 auto`,\r\n padding: `0`,\r\n whiteSpace:cssObject?.whiteSpace?.[cssKeys?.normal],\r\n textAlign: cssObject?.side?.[cssKeys?.start],\r\n listStyle:\"none\",\r\n color: cssObject?.color?.[cssKeys?.bodyColor],\r\n width: \"98%\",\r\n justifyContent: \"flex-start\",\r\n overflowX: \"auto\",\r\n alignItems: \"center\",\r\n position: \"relative\",\r\n fontSize: cssObject?.text?.size?.[cssKeys?.body3],\r\n },\r\n [classesName?.breadcrumbs_item]: {\r\n display: cssObject?.display?.[cssKeys?.inlineFlex],\r\n margin: `0`,\r\n padding: `1px ${cssObject?.spacing?.[cssKeys?.xs]}`,\r\n textAlign: cssObject?.side?.[cssKeys?.start],\r\n listStyle:\"none\",\r\n position: \"relative\",\r\n color: cssObject?.color?.[cssKeys?.currentColor],\r\n // width: \"100%\",\r\n justifyContent: \"flex-start\",\r\n overflowX: \"auto\",\r\n alignItems: \"center\",\r\n \"&last-of-type\":{\r\n [`.${classesName?.breadcrumbs_separator}`]:{\r\n display: \"none\"\r\n }\r\n }\r\n },\r\n [classesName?.breadcrumbs_item_hover]: {\r\n \"&hover\":{\r\n borderBlockEnd:\"1px solid\",\r\n borderColor: cssObject?.color?.[cssKeys?.currentColor],\r\n cursor: \"pointer\"\r\n\r\n }\r\n },\r\n [classesName?.breadcrumbs_item_last]: {\r\n color: styleFunction.checkColorReturnValue(\"primary\"),\r\n borderBlockEnd:\"1px solid\",\r\n borderColor: cssObject?.color?.[cssKeys?.currentColor],\r\n },\r\n [classesName?.breadcrumbs_separator]: {\r\n display: cssObject?.display?.[cssKeys?.inlineBlock],\r\n margin:\"0 auto\",\r\n padding: `0 ${cssObject?.spacing?.[cssKeys?.xs]}`,\r\n textAlign: cssObject?.side?.[cssKeys?.center],\r\n position: \"relative\",\r\n color: cssObject?.color?.[cssKeys?.currentColor],\r\n width: \"100%\",\r\n justifyContent: \"flex-start\",\r\n overflowX: \"auto\",\r\n alignItems: \"center\",\r\n opacity: \".8\",\r\n\r\n },\r\n },\r\n });\r\n\r\n const styleSx = StyleBuilder({\r\n blnRandomPrefix: true,\r\n blnIsDefaultStyle: false,\r\n blnCbmisStyle: true,\r\n objStyles: {\r\n [classesName?.sx]: (props) => {\r\n return {\r\n ...props?.sx,\r\n color: styleFunction.checkColorReturnValue(props?.color || props?.sx?.color || \"var(--cbmis-body-color-dark)\"),\r\n \r\n };\r\n },\r\n }\r\n });\r\n\r\n return{\r\n classesName,\r\n style,\r\n styleSx,\r\n }\r\n}","import { StyleBuilder, styleVariables } from \"@cbmisorg/styles\";\r\n\r\nexport const classesName = {\r\n drawer: `${styleVariables?.prefixDefaultClassName}_drawer`,\r\n drawerOpen: `${styleVariables?.prefixDefaultClassName}_drawer_open`,\r\n\r\n drawerContainer: `${styleVariables?.prefixDefaultClassName}_drawerContainer`,\r\n sx: `${styleVariables?.prefixDefaultClassName}_drawer_sx`,\r\n\r\n buttonSwipe: `${styleVariables?.prefixDefaultClassName}_buttonSwipe`,\r\n\r\n groupBar: `${styleVariables?.prefixDefaultClassName}_group_bar`,\r\n nav: `${styleVariables?.prefixDefaultClassName}_nav_item`,\r\n nav_item_item_content: `${styleVariables?.prefixDefaultClassName}_nav_item_item_content`,\r\n\r\n menu_container: `${styleVariables?.prefixDefaultClassName}_menu_container`,\r\n menu: `${styleVariables?.prefixDefaultClassName}_menu`,\r\n menu_bg_dialog_open: `${styleVariables?.prefixDefaultClassName}_menu_bg_dialog_open`,\r\n\r\n};\r\nexport const style = StyleBuilder({\r\n blnRandomPrefix: false,\r\n blnIsDefaultStyle: true,\r\n blnCbmisStyle: true,\r\n objStyles: {\r\n [classesName?.buttonSwipe]: {\r\n height: \"20px\",\r\n width: \"25px\",\r\n position: \"absolute\",\r\n zIndex: \"1000\",\r\n display: \"flex\",\r\n alignItems: \"center\",\r\n justifyContent: \"center\",\r\n background: \"#fff\",\r\n borderRadius: \"8px\",\r\n boxShadow: \"2px 2px 1px 0 #ababab4d\",\r\n cursor: \"pointer\",\r\n xs: {\r\n marginInlineStart: \"35vw\",\r\n },\r\n sm: {\r\n marginInlineStart: \"70vw\",\r\n },\r\n md: {\r\n marginInlineStart: \"80vw\",\r\n },\r\n lg: {\r\n marginInlineStart: \"85vw\",\r\n },\r\n xl: {\r\n marginInlineStart: \"90vw\",\r\n },\r\n },\r\n [classesName?.drawer]: {\r\n background: \"#f8fafc\",\r\n transition: \"box-shadow 300ms cubic-bezier(0.4, 0, 0.2, 1) 1ms\",\r\n boxShadow: \"0 0 0 1px rgba(0, 0, 0, 0.05)\",\r\n display: \"none\",\r\n flexDirection: \"column\",\r\n flex: \"1 0 auto\",\r\n bottom: \"auto\",\r\n outline: \"0px\",\r\n left: \"0px\",\r\n right: \"auto\",\r\n minWidth: \"0px\",\r\n opacity: 0,\r\n zIndex: \"1000\",\r\n overflow: \"auto\",\r\n [`.${classesName?.groupBar}`]: {\r\n display: \"block !important\",\r\n },\r\n [`.${classesName?.nav}`]: {\r\n minWidth: \"100%\",\r\n [`.${classesName?.nav_item_item_content}`]: {\r\n margin: \"0px\",\r\n width: \"90%\",\r\n },\r\n },\r\n [`.${classesName?.menu_container}`]: {\r\n minWidth: \"100%\",\r\n },\r\n [`.${classesName?.menu}`]: {\r\n position: \"relative !important\",\r\n width: \"100% !important\",\r\n boxShadow: \"none !important\",\r\n borderRadius: \"0 !important\",\r\n padding: \"0 !important\",\r\n top: \"initial !important\",\r\n left: \"initial !important\",\r\n right: \"initial !important\",\r\n },\r\n [`.${classesName?.menu_bg_dialog_open}`]:{\r\n position: \"relative\",\r\n display: \"none\",\r\n width: \"0\",\r\n top: 0,\r\n left: 0,\r\n height: \"0\",\r\n zIndex: \"-1 !important\",\r\n },\r\n },\r\n\r\n },\r\n});\r\n\r\nexport const styleSx = StyleBuilder({\r\n blnRandomPrefix: true,\r\n blnIsDefaultStyle: false,\r\n blnCbmisStyle: true,\r\n objStyles: {\r\n [classesName?.drawer]: (props) => {\r\n return {\r\n ...open(props?.open),\r\n ...mode(props?.mode),\r\n };\r\n },\r\n [classesName?.sx]: (props) => {\r\n return {\r\n ...props?.sx,\r\n };\r\n },\r\n },\r\n});\r\n\r\nconst mode = (mode) => {\r\n const getMode = String(mode)?.toLowerCase();\r\n switch (getMode) {\r\n case \"dashboard\":\r\n return {\r\n position: \"sticky\",\r\n top: \"70px\",\r\n height: \"calc(100% - 200px)\",\r\n };\r\n default:\r\n return {\r\n position: \"fixed\",\r\n };\r\n }\r\n};\r\n\r\nconst open = (open) => {\r\n return {\r\n display: \"block\",\r\n opacity: 1,\r\n overflow: \"auto\",\r\n minHeight: \"calc(-68px + 100vh)\",\r\n maxHeight: \"calc(-58px + 100vh)\",\r\n padding: \"0.5rem\",\r\n xs: {\r\n minWidth: \"65vw\",\r\n maxWidth: \"65vw\",\r\n },\r\n sm: {\r\n minWidth: \"30vw\",\r\n maxWidth: \"30vw\",\r\n },\r\n md: {\r\n minWidth: \"20vw\",\r\n maxWidth: \"20vw\",\r\n },\r\n lg: {\r\n minWidth: \"15vw\",\r\n maxWidth: \"15vw\",\r\n },\r\n xl: {\r\n minWidth: \"10vw\",\r\n maxWidth: \"10vw\",\r\n },\r\n };\r\n};\r\n\r\n\r\nexport default(objThemeInfo)=>{\r\n const cssObject = objThemeInfo?.cssObject || mainTheme?.cssObject;\r\n const currentBaseSize = objThemeInfo?.currentBaseSize || mainTheme?.currentBaseSize;\r\n const classesName = {\r\n drawer: `${styleVariables?.prefixDefaultClassName}_drawer`,\r\n drawerOpen: `${styleVariables?.prefixDefaultClassName}_drawer_open`,\r\n \r\n drawerContainer: `${styleVariables?.prefixDefaultClassName}_drawerContainer`,\r\n sx: `${styleVariables?.prefixDefaultClassName}_drawer_sx`,\r\n \r\n buttonSwipe: `${styleVariables?.prefixDefaultClassName}_buttonSwipe`,\r\n \r\n groupBar: `${styleVariables?.prefixDefaultClassName}_group_bar`,\r\n nav: `${styleVariables?.prefixDefaultClassName}_nav_item`,\r\n nav_item_item_content: `${styleVariables?.prefixDefaultClassName}_nav_item_item_content`,\r\n \r\n menu_container: `${styleVariables?.prefixDefaultClassName}_menu_container`,\r\n menu: `${styleVariables?.prefixDefaultClassName}_menu`,\r\n menu_bg_dialog_open: `${styleVariables?.prefixDefaultClassName}_menu_bg_dialog_open`,\r\n \r\n };\r\n const style = StyleBuilder({\r\n blnRandomPrefix: false,\r\n blnIsDefaultStyle: true,\r\n blnCbmisStyle: true,\r\n objStyles: {\r\n [classesName?.buttonSwipe]: {\r\n height: \"20px\",\r\n width: \"25px\",\r\n position: \"absolute\",\r\n zIndex: \"1000\",\r\n display: \"flex\",\r\n alignItems: \"center\",\r\n justifyContent: \"center\",\r\n background: \"#fff\",\r\n borderRadius: \"8px\",\r\n boxShadow: \"2px 2px 1px 0 #ababab4d\",\r\n cursor: \"pointer\",\r\n xs: {\r\n marginInlineStart: \"35vw\",\r\n },\r\n sm: {\r\n marginInlineStart: \"70vw\",\r\n },\r\n md: {\r\n marginInlineStart: \"80vw\",\r\n },\r\n lg: {\r\n marginInlineStart: \"85vw\",\r\n },\r\n xl: {\r\n marginInlineStart: \"90vw\",\r\n },\r\n },\r\n [classesName?.drawer]: {\r\n background: \"#f8fafc\",\r\n transition: \"box-shadow 300ms cubic-bezier(0.4, 0, 0.2, 1) 1ms\",\r\n boxShadow: \"0 0 0 1px rgba(0, 0, 0, 0.05)\",\r\n display: \"none\",\r\n flexDirection: \"column\",\r\n flex: \"1 0 auto\",\r\n bottom: \"auto\",\r\n outline: \"0px\",\r\n left: \"0px\",\r\n right: \"auto\",\r\n minWidth: \"0px\",\r\n opacity: 0,\r\n zIndex: \"1000\",\r\n overflow: \"auto\",\r\n [`.${classesName?.groupBar}`]: {\r\n display: \"block !important\",\r\n },\r\n [`.${classesName?.nav}`]: {\r\n minWidth: \"100%\",\r\n // fontSize: cssObject?.text?.size?.[cssKeys?.subtitle3],\r\n [`.${classesName?.nav_item_item_content}`]: {\r\n margin: \"0px\",\r\n width: \"90%\",\r\n },\r\n },\r\n [`.${classesName?.menu_container}`]: {\r\n minWidth: \"100%\",\r\n },\r\n [`.${classesName?.menu}`]: {\r\n position: \"relative !important\",\r\n width: \"100% !important\",\r\n boxShadow: \"none !important\",\r\n borderRadius: \"0 !important\",\r\n padding: \"0 !important\",\r\n top: \"initial !important\",\r\n left: \"initial !important\",\r\n right: \"initial !important\",\r\n },\r\n [`.${classesName?.menu_bg_dialog_open}`]:{\r\n position: \"relative\",\r\n display: \"none\",\r\n width: \"0\",\r\n top: 0,\r\n left: 0,\r\n height: \"0\",\r\n zIndex: \"-1 !important\",\r\n },\r\n },\r\n \r\n },\r\n });\r\n \r\n const styleSx = StyleBuilder({\r\n blnRandomPrefix: true,\r\n blnIsDefaultStyle: false,\r\n blnCbmisStyle: true,\r\n objStyles: {\r\n [classesName?.drawer]: (props) => {\r\n return {\r\n ...open(props?.open),\r\n ...mode(props?.mode),\r\n };\r\n },\r\n [classesName?.sx]: (props) => {\r\n return {\r\n ...props?.sx,\r\n };\r\n },\r\n },\r\n });\r\n\r\n return{\r\n classesName,\r\n style,\r\n styleSx\r\n }\r\n}","\"use client\";\r\nimport { useEffect, useState } from \"react\";\r\n\r\nexport default function useScreenSize() {\r\n function getSize() {\r\n const isClient = typeof window !== \"undefined\";\r\n\r\n if (typeof window !== \"undefined\") {\r\n return {\r\n width: window.innerWidth,\r\n height: window.innerHeight,\r\n };\r\n }\r\n return { width: undefined, height: undefined };\r\n }\r\n\r\n const [windowSize, setWindowSize] = useState({ width: undefined, height: undefined });\r\n\r\n useEffect(() => {\r\n function handleResize() {\r\n setWindowSize(getSize());\r\n }\r\n\r\n if (typeof window !== \"undefined\") {\r\n window.addEventListener(\"resize\", handleResize);\r\n }\r\n return () => {\r\n if (typeof window !== \"undefined\") {\r\n window.removeEventListener(\"resize\", handleResize);\r\n }\r\n };\r\n }, []);\r\n\r\n return windowSize;\r\n}\r\n","import { useEffect, useRef } from \"react\";\r\n\r\nexport const useClickOutside = (handler) => {\r\n const domNode = useRef();\r\n useEffect(() => {\r\n const eventHandler = (event) => {\r\n if (!domNode?.current?.contains(event.target)) {\r\n handler();\r\n }\r\n // uncomment this for dropdown close on menu click\r\n // handler();\r\n }\r\n document.addEventListener(\"mousedown\", eventHandler);\r\n return () => {\r\n document.removeEventListener('mousedown', eventHandler);\r\n }\r\n });\r\n return domNode;\r\n }","import React, { forwardRef, useEffect, useId } from \"react\";\r\nimport { classesName, style, styleSx } from \"./DrawerStyle\";\r\nimport { cssKeys, styleFunction, styleVariables } from \"@cbmisorg/styles\";\r\nimport ErrorBoundary from \"../../_helper/errorHandeling/ErrorBoundary/ErrorBoundary\";\r\nimport useScreenSize from \"../../_helper/hooks/useScreenSize\";\r\nimport { useClickOutside } from \"../../_helper/hooks/useClickOutside\";\r\n\r\nconst Drawer = forwardRef(function Drawer(/**@type {any}*/ props, ref) {\r\n const { open, eventClose, blnSwap = false, mode, ...rest } = props;\r\n const classes = style();\r\n const { width } = useScreenSize();\r\n\r\n const dropdownNode = useClickOutside(() => {\r\n if (open === true && (mode !== \"dashboard\" || width < parseFloat(styleVariables?.mdScr))) {\r\n eventClose();\r\n }\r\n });\r\n\r\n return (\r\n <>\r\n \r\n {open ? : null}\r\n
\r\n {\r\n // !blnSwap ? null : (\r\n // \r\n // {open ? \"<\" : \">\"}\r\n // \r\n // )\r\n }\r\n >\r\n );\r\n});\r\n\r\nconst DrawerChild = forwardRef(function Drawer(/**@type {any}*/ props, ref) {\r\n const { open, position, eventClose, color, title, blnHaveTitle = true, mode, textColor, width, sx, hidden, disabled, dir, className, id, ...rest } = props;\r\n const classes = style();\r\n const classesSx = styleSx({ sx, open });\r\n const itemClasses = styleFunction.getClassName(\r\n classes?.[classesName?.drawer],\r\n classesSx?.[classesName?.drawer],\r\n classesSx?.[classesName?.sx],\r\n styleFunction.CheckDirectionItem(dir),\r\n styleFunction.CheckDisabledItem(disabled),\r\n styleFunction.CheckHiddenItem(hidden),\r\n styleFunction.checkExistsMargin(rest),\r\n styleFunction.checkExistsPadding(rest),\r\n className\r\n );\r\n\r\n const comID = id || String(useId()).slice(1, -1);\r\n\r\n return (\r\n \r\n \r\n {props?.children} \r\n
\r\n \r\n );\r\n});\r\nexport default Drawer;\r\n","import React, { forwardRef, useContext, useEffect, useId, useState } from \"react\";\r\nimport { ContextThemeProvider, styleFunction } from \"@cbmisorg/styles\";\r\nimport StepperStyle from \"./StepperStyle\";\r\nimport ErrorBoundary from \"../../_helper/errorHandeling/ErrorBoundary/ErrorBoundary\";\r\nimport { Icon } from \"@cbmisorg/icons\";\r\n\r\nconst Stepper = forwardRef((/**@type {any}*/ props, ref) => {\r\n const theTheme = useContext(ContextThemeProvider);\r\n const { classesName, style, styleSx } = StepperStyle(theTheme);\r\n const { mode, stepperContent, currentStep, completedColor, activeColor, stepClicked, blnCanStepClicked, sx, hidden, disabled, dir, className, id, ...rest } = props;\r\n const classes = style();\r\n const classesSx = styleSx({ sx, activeColor });\r\n const [currentTabIndex, setCurrentTabIndex] = useState(0);\r\n const [stepperContentArr, setStepperContentArr] = useState([]);\r\n const comID = id || String(useId()).slice(1, -1) + \"Stepper\";\r\n\r\n const itemClasses = styleFunction.getClassName(\r\n classes?.[classesName?.stepper],\r\n classesSx?.[classesName?.sx],\r\n styleFunction.CheckDirectionItem(dir),\r\n styleFunction.CheckDisabledItem(disabled),\r\n styleFunction.CheckHiddenItem(hidden),\r\n styleFunction.checkExistsMargin(rest),\r\n styleFunction.checkExistsPadding(rest)\r\n );\r\n\r\n const navigateToStepHandler = (e) => {\r\n if (Number(e.target.value) !== currentTabIndex && blnCanStepClicked) {\r\n setCurrentTabIndex(Number(e.target.value));\r\n }\r\n };\r\n\r\n useEffect(() => {}, [mode, stepperContent, currentStep, completedColor, stepClicked, blnCanStepClicked, activeColor, hidden, disabled, dir, className, id]);\r\n\r\n useEffect(() => {\r\n if (currentStep && parseInt(currentStep) > 1) {\r\n setCurrentTabIndex(parseInt(currentStep) - 1);\r\n } else {\r\n setCurrentTabIndex(0);\r\n }\r\n }, [currentStep]);\r\n\r\n useEffect(() => {\r\n if (stepperContent) {\r\n setStepperContentArr(stepperContent || []);\r\n }\r\n }, [stepperContent]);\r\n\r\n return (\r\n \r\n
{props.children} \r\n
\r\n {stepperContentArr.map((el, i) => (\r\n
\r\n \r\n = i? styleFunction.checkColorReturnValue(activeColor || \"primary\") :null}}>\r\n {currentTabIndex<= i? i+1: } \r\n \r\n {el?.label}\r\n \r\n
\r\n \r\n ))}\r\n
\r\n\r\n
\r\n {stepperContentArr?.[currentTabIndex]?.content} \r\n\r\n
\r\n
\r\n );\r\n});\r\n\r\nexport default Stepper;\r\n","import React, { forwardRef, useContext, useId } from 'react'\r\nimport {ContextThemeProvider, styleFunction} from \"@cbmisorg/styles\";\r\nimport ErrorBoundary from '../../_helper/errorHandeling/ErrorBoundary/ErrorBoundary';\r\nimport GroupBarStyle from './GroupBarStyle';\r\n\r\nconst GroupBar = forwardRef(function GroupBar(/**@type {any}*/props,ref) {\r\n const theTheme = useContext(ContextThemeProvider);\r\n const { sx, hidden, disabled, dir, className, id, position={xl:\"\",lg:\"\",md:\"\",sm:\"\",xs:\"\"}, ...rest } = props;\r\n const {classesName, style, styleSx} = GroupBarStyle(theTheme);\r\n const classes = style();\r\n const classesSx = styleSx({sx});\r\n const itemClasses = styleFunction.getClassName(classes?.[classesName?.groupBar], classesSx?.[classesName?.sx], styleFunction.CheckDirectionItem(dir),styleFunction.CheckDisabledItem(disabled), styleFunction.CheckHiddenItem(hidden),styleFunction.checkExistsMargin(rest),styleFunction.checkExistsPadding(rest), className);\r\n\r\n const comID = id || String(useId()).slice(1,-1)\r\n\r\n return (\r\n \r\n {props.children} \r\n
\r\n )\r\n})\r\n\r\nexport default GroupBar","import { StyleBuilder, styleVariables, cssKeys, mainTheme } from \"@cbmisorg/styles\";\r\n\r\nexport default (objThemeInfo) => {\r\n const cssObject = objThemeInfo?.cssObject || mainTheme?.cssObject;\r\n\r\n const classesName = {\r\n stepper: `${styleVariables?.prefixDefaultClassName}_stepper`,\r\n stepper_head: `${styleVariables?.prefixDefaultClassName}_stepper_head`,\r\n stepper_label: `${styleVariables?.prefixDefaultClassName}_stepper_label`,\r\n stepper_body: `${styleVariables?.prefixDefaultClassName}_stepper_body`,\r\n stepper_steps: `${styleVariables?.prefixDefaultClassName}_stepper_steps`,\r\n stepper_step: `${styleVariables?.prefixDefaultClassName}_stepper_step`,\r\n stepper_step_input: `${styleVariables?.prefixDefaultClassName}_stepper_step_input`,\r\n\r\n sx: `${styleVariables?.prefixDefaultClassName}_stepper_sx`,\r\n };\r\n\r\n const style = StyleBuilder({\r\n blnRandomPrefix: false,\r\n blnIsDefaultStyle: true,\r\n blnCbmisStyle: true,\r\n objStyles: {\r\n [classesName?.stepper]: {\r\n display: cssObject?.display?.[cssKeys?.block],\r\n boxSizing: cssObject?.boxSizing?.[cssKeys?.borderBox],\r\n position: cssObject?.position?.[cssKeys?.relative],\r\n margin: \"auto\",\r\n minHeight: \"max-content\",\r\n width: \"100%\",\r\n \">*\": {\r\n boxSizing: cssObject?.boxSizing?.[cssKeys?.borderBox],\r\n position: cssObject?.position?.[cssKeys?.relative],\r\n },\r\n },\r\n [classesName?.stepper_body]: {\r\n flex: 1,\r\n padding: 0,\r\n position: cssObject?.position?.[cssKeys?.relative],\r\n },\r\n [classesName?.stepper_head]: {\r\n display: \"flex\",\r\n justifyContent:\"space-between\",\r\n position: \"relative\",\r\n width: \"100%\",\r\n userSelect: \"none\",\r\n counterReset: \"current-step\", \r\n gridTemplateColumns: \"repeat( auto-fit, minmax(1px, 1fr) )\",\r\n zIndex: 1,\r\n \"&after\":{\r\n content:\"' '\",\r\n display: cssObject?.display?.[cssKeys?.block],\r\n position: \"absolute\",\r\n top:\"37%\",\r\n left:\"0\",\r\n margin: \"auto\",\r\n width: \"100%\",\r\n minHeight: \"1px\",\r\n maxHeight: \"1px\",\r\n background:\"currentColor\",\r\n zIndex: -1,\r\n }\r\n },\r\n [classesName?.stepper_step_input]: {\r\n position: \"absolute\",\r\n display: \"initial\",\r\n top: \"-2rem\",\r\n opacity:0,\r\n },\r\n [classesName?.stepper_steps]: {\r\n position: \"relative\",\r\n display: \"block\",\r\n margin: \"0\",\r\n cursor:\"pointer\",\r\n fontSize: cssObject?.text?.size?.[cssKeys?.subtitle3],\r\n fontWeight: cssObject?.text?.fontWeight?.[cssKeys?.fontWeight_md],\r\n\r\n },\r\n [classesName?.stepper_step]: {\r\n position: \"relative\",\r\n display: \"flex\",\r\n width:\"35px\",\r\n height:\"35px\",\r\n border:`1px solid currentColor`,\r\n borderRadius:\"100%\",\r\n textAlign:\"center\",\r\n fontSize: cssObject?.text?.size?.[cssKeys?.h6],\r\n cursor:\"pointer\",\r\n justifyContent:\"center\",\r\n alignItems:\"center\",\r\n },\r\n [classesName?.stepper_label]: {\r\n position: \"relative\",\r\n display: \"block\",\r\n margin: \"0.5rem 0\",\r\n zIndex: 2,\r\n cursor:\"pointer\",\r\n\r\n },\r\n },\r\n });\r\n\r\n const styleSx = StyleBuilder({\r\n blnRandomPrefix: true,\r\n blnIsDefaultStyle: false,\r\n blnCbmisStyle: true,\r\n objStyles: {\r\n // [classesName?.stepper_head]: (props) => {\r\n // if (String(props?.mode).toLowerCase() === \"isvertical\") {\r\n // return {\r\n // flexDirection: \"column\",\r\n // width: \"auto\",\r\n // [`.${classesName?.stepper_step}`]: {\r\n // display: \"flex\",\r\n // alignItems: \"center\",\r\n // textAlign: \"start\",\r\n // \"&after\": {\r\n // content: \" \",\r\n // position: \"absolute\",\r\n // margin: \"auto 1rem\",\r\n // top: \"2rem\",\r\n // bottom: \"-0.5rem\",\r\n // width: 0,\r\n // height: \"auto\",\r\n // borderLeft: \"0.125rem solid #ccc\",\r\n // },\r\n // },\r\n // [`.${classesName?.stepper_label}`]: {\r\n // paddingInlineStart: \"1rem\"\r\n // },\r\n // \"&+\": {\r\n // [`.${classesName?.stepper_body}`]: {\r\n // marginInlineStart: \" 3.5rem\",\r\n // },\r\n // },\r\n // };\r\n // }else{\r\n // return {\r\n // flexDirection: \"row\",\r\n // width: \"100%\",\r\n // [`.${classesName?.stepper_step}`]: {\r\n // display: \"flex\",\r\n // alignItems: \"center\",\r\n // textAlign: \"start\",\r\n // \"&after\": {\r\n // content: \" \",\r\n // position: \"absolute\",\r\n // margin: \"auto 1rem\",\r\n // top: \"50%\",\r\n // transform: \"translateY(-50%)\",\r\n // },\r\n // },\r\n // [`.${classesName?.stepper_label}`]: {\r\n // paddingInlineStart: \"1rem\"\r\n // },\r\n // \"&+\": {\r\n // [`.${classesName?.stepper_body}`]: {\r\n // marginInlineStart: \" 3.5rem\",\r\n // },\r\n // },\r\n // };\r\n // }\r\n // },\r\n [classesName?.sx]: (props) => {\r\n return props?.sx;\r\n },\r\n },\r\n });\r\n\r\n return {\r\n classesName,\r\n style,\r\n styleSx,\r\n };\r\n};\r\n","import { StyleBuilder, styleVariables, cssKeys, mainTheme, styleFunction } from \"@cbmisorg/styles\";\r\n\r\nexport default (objThemeInfo) => {\r\n const cssObject = objThemeInfo?.cssObject || mainTheme?.cssObject;\r\n\r\n const classesName = {\r\n slideshow: `${styleVariables?.prefixDefaultClassName}_slideshow`,\r\n slideshowSlider: `${styleVariables?.prefixDefaultClassName}_slideshowSlider`,\r\n slide: `${styleVariables?.prefixDefaultClassName}_slide`,\r\n slide_containt: `${styleVariables?.prefixDefaultClassName}_slide_containt`,\r\n slide_showDots: `${styleVariables?.prefixDefaultClassName}_slide_showDots`,\r\n slide_showDot: `${styleVariables?.prefixDefaultClassName}_slide_showDot`,\r\n slide_showDot_active: `${styleVariables?.prefixDefaultClassName}_slide_showDot_active`,\r\n slide_btn: `${styleVariables?.prefixDefaultClassName}_slide_btn`,\r\n slide_btn_prev: `${styleVariables?.prefixDefaultClassName}_slide_btn_prev`,\r\n slide_btn_next: `${styleVariables?.prefixDefaultClassName}_slide_btn_next`,\r\n\r\n sx: `${styleVariables?.prefixDefaultClassName}_slideshow_sx`,\r\n sx_slide: `${styleVariables?.prefixDefaultClassName}_slide_sx`,\r\n };\r\n\r\n const style = StyleBuilder({\r\n blnRandomPrefix: false,\r\n blnIsDefaultStyle: true,\r\n blnCbmisStyle: true,\r\n objStyles: {\r\n [classesName?.slideshow]: {\r\n display: cssObject?.display?.[cssKeys?.block],\r\n boxSizing: cssObject?.boxSizing?.[cssKeys?.borderBox],\r\n position: cssObject?.position?.[cssKeys?.relative],\r\n minHeight: \"max-content\",\r\n margin: 0,\r\n overflowY: \"visible\",\r\n overflowX: \"clip\",\r\n width: \"100%\",\r\n },\r\n [classesName?.slideshowSlider]: {\r\n whiteSpace: \"nowrap\",\r\n transition: \"ease 1000ms\",\r\n position: cssObject?.position?.[cssKeys?.relative],\r\n direction: \"inherit\",\r\n display: \"flex\",\r\n },\r\n [classesName?.slide]: {\r\n display: cssObject?.display?.[cssKeys?.block],\r\n minHeight: \"250px\",\r\n height: \"100%\",\r\n borderRadius: cssObject?.border?.[cssKeys?.rounded]?.xs,\r\n background: styleFunction.checkColorReturnValue(cssObject?.color?.[cssKeys?.light]),\r\n position: cssObject?.position?.[cssKeys?.relative],\r\n margin: \"0 auto\",\r\n backgroundPosition: \"center\",\r\n backgroundSize: \"100% 100%\",\r\n backgroundRepeat: \"no-repeat\",\r\n },\r\n [classesName?.slide_containt]: {\r\n position: cssObject?.position?.[cssKeys?.relative],\r\n top: 0,\r\n left: 0,\r\n right: 0,\r\n bottom: 0,\r\n display: cssObject?.display?.[cssKeys?.block],\r\n padding: \"1px\",\r\n width: \"100%\",\r\n height: \"100%\",\r\n },\r\n [classesName?.slide_showDots]: {\r\n textAlign: \"center\",\r\n width: \"100%\",\r\n position: cssObject?.position?.[cssKeys?.absolute],\r\n bottom: 0,\r\n zIndex: 1,\r\n },\r\n [classesName?.slide_showDot]: {\r\n position: \"relative\",\r\n display: \"inline-block\",\r\n height: \"7px\",\r\n width: \"7px\",\r\n borderRadius: \"50%\",\r\n cursor: \"pointer\",\r\n margin: \"10px 7px\",\r\n background: styleFunction.checkColorReturnValue(cssObject?.color?.[cssKeys?.bodyColor]),\r\n border: `2px solid ${styleFunction.checkColorReturnValue(cssObject?.color?.[cssKeys?.bodyColor])}`,\r\n \"&hover\": {\r\n opacity: 0.9,\r\n background: \"transparent\",\r\n },\r\n },\r\n [classesName?.slide_btn]: {\r\n position: \"absolute\",\r\n width: \"25px\",\r\n height: \"25px\",\r\n background: \"transparent\",\r\n border: `1px solid ${styleFunction.checkColorReturnValue(cssObject?.color?.[cssKeys?.bodyColor])}`,\r\n cursor: \"pointer\",\r\n overflow: \"hidden\",\r\n zIndex: 10,\r\n display: \"flex\",\r\n justifyContent: \"center\",\r\n alignItems: \"center\",\r\n color: styleFunction.checkColorReturnValue(cssObject?.color?.[cssKeys?.bodyColor]),\r\n fontSize: \"18px\",\r\n borderRadius: \"100%\",\r\n top: \"50%\",\r\n transform: \"translateY(-60%)\",\r\n },\r\n [classesName?.slide_btn_prev]: {\r\n left: \"20px\",\r\n },\r\n [classesName?.slide_btn_next]: {\r\n right: \"20px\",\r\n },\r\n },\r\n });\r\n\r\n const styleSx = StyleBuilder({\r\n blnRandomPrefix: true,\r\n blnIsDefaultStyle: false,\r\n blnCbmisStyle: true,\r\n objStyles: {\r\n [classesName?.slide_showDot_active]: (props) => {\r\n return {\r\n background: styleFunction.checkColorReturnValue(props?.activeColor || cssObject?.color?.[cssKeys?.primary]),\r\n borderColor: styleFunction.checkColorReturnValue(props?.activeColor || cssObject?.color?.[cssKeys?.primary]),\r\n };\r\n },\r\n [classesName?.sx]: (props) => {\r\n return {\r\n ...props?.sx,\r\n };\r\n },\r\n [classesName?.slideshowSlider]: (props) => {\r\n if (props.slideNumber) {\r\n return {\r\n [`.${classesName?.slide}`]: {\r\n flex: ` 1 0 ${100 / (Number(props.slideNumber) || 1)}%`,\r\n },\r\n };\r\n }\r\n return {\r\n [`.${classesName?.slide}`]: {\r\n flex: ` 1 0 100%`,\r\n },\r\n };\r\n },\r\n [classesName?.slide]: (props) => {\r\n if (props.image) {\r\n return {\r\n backgroundImage: `url(${props.image})`,\r\n };\r\n }\r\n return null;\r\n },\r\n [classesName?.sx_slide]: (props) => {\r\n return {\r\n ...props?.sx,\r\n };\r\n },\r\n },\r\n });\r\n\r\n return {\r\n classesName,\r\n style,\r\n styleSx,\r\n };\r\n};\r\n","import React, { forwardRef, useContext, useEffect, useRef, useState } from \"react\";\r\nimport { ContextThemeProvider, styleFunction } from \"@cbmisorg/styles\";\r\nimport SlideshowStyle from \"./SlideshowStyle\";\r\nimport ErrorBoundary from \"../../_helper/errorHandeling/ErrorBoundary/ErrorBoundary\";\r\nimport { Icon } from \"@cbmisorg/icons\";\r\n\r\nconst Slideshow = forwardRef((/**@type {any}*/ props, ref) => {\r\n const theTheme = useContext(ContextThemeProvider);\r\n const { classesName, style, styleSx } = SlideshowStyle(theTheme);\r\n const { blnAutoShow=true, delay, activeColor, blnDotsShow = true, blnArrow = true, slideNumber = 1, sx, hidden, disabled, dir, className, ...rest } = props;\r\n const slides = props?.children || [];\r\n const classes = style();\r\n const classesSx = styleSx({ sx, activeColor, slideNumber });\r\n\r\n const [index, setIndex] = useState(0);\r\n const timeoutRef = useRef(null);\r\n // const sliderSplitNum = new Array(Math.round(slides.length / slideNumber));\r\n\r\n const canMove = Math.round(slides.length / slideNumber) > 1;\r\n const isAutoShow = blnAutoShow && canMove;\r\n const timeDelay = delay || 3000;\r\n\r\n useEffect(() => {}, [slides, blnAutoShow, delay, activeColor, blnDotsShow, blnArrow, sx, hidden, disabled, dir, className]);\r\n\r\n useEffect(() => {\r\n if (isAutoShow) {\r\n resetTimeout();\r\n timeoutRef.current = setTimeout(() => setIndex((prevIndex) => (prevIndex === slides.length - 1 ? 0 : prevIndex + 1)), timeDelay);\r\n\r\n return () => {\r\n resetTimeout();\r\n };\r\n }\r\n }, [index]);\r\n\r\n const itemClasses = styleFunction.getClassName(\r\n classes?.[classesName?.slideshow],\r\n classesSx?.[classesName?.sx],\r\n styleFunction.CheckDirectionItem(dir),\r\n styleFunction.CheckDisabledItem(disabled),\r\n styleFunction.CheckHiddenItem(hidden),\r\n styleFunction.checkExistsMargin(rest),\r\n styleFunction.checkExistsPadding(rest),\r\n className\r\n );\r\n\r\n function resetTimeout() {\r\n if (timeoutRef.current) {\r\n clearTimeout(timeoutRef.current);\r\n }\r\n }\r\n\r\n const handleNext = () => {\r\n if (canMove && blnArrow) {\r\n var next = index + 1;\r\n // if (next === sliderSplitNum.length) {\r\n // next = 0;\r\n // }\r\n setIndex(next);\r\n }\r\n };\r\n\r\n const handlePrev = () => {\r\n if (canMove && blnArrow) {\r\n var Prev = index - 1;\r\n if (Prev === -1) {\r\n // Prev = sliderSplitNum.length - 1;\r\n }\r\n setIndex(Prev);\r\n }\r\n };\r\n\r\n return (\r\n \r\n
\r\n \r\n {props.children}\r\n
\r\n \r\n {canMove && blnArrow ? (\r\n
\r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n \r\n ) : (\r\n \"\"\r\n )}\r\n {blnDotsShow && canMove ? (\r\n
\r\n {(props.children || []).map((_, idx) => (\r\n
{\r\n setIndex(idx);\r\n }}\r\n >
\r\n ))}\r\n
\r\n ) : (\r\n \"\"\r\n )}\r\n
\r\n );\r\n});\r\n\r\nexport default Slideshow;\r\n","import React, { forwardRef, useContext } from \"react\";\r\nimport { ContextThemeProvider, styleFunction } from \"@cbmisorg/styles\";\r\nimport SlideshowStyle from \"./SlideshowStyle\";\r\nimport ErrorBoundary from \"../../_helper/errorHandeling/ErrorBoundary/ErrorBoundary\";\r\nimport { useId } from \"react\";\r\n\r\nconst Slide = forwardRef((/**@type {any}*/ props, ref) => {\r\n const theTheme = useContext(ContextThemeProvider);\r\n const { classesName, style, styleSx } = SlideshowStyle(theTheme);\r\n const { image, sx, hidden, disabled, dir, className, id, ...rest } = props;\r\n const classes = style();\r\n const classesSx = styleSx({ sx, image });\r\n const comID = id || String(useId()).slice(1, -1) + \"slide\";\r\n\r\n const itemClasses = styleFunction.getClassName(\r\n classes?.[classesName?.slide],\r\n classesSx?.[classesName?.slide],\r\n classesSx?.[classesName?.sx],\r\n styleFunction.CheckDirectionItem(dir),\r\n styleFunction.CheckDisabledItem(disabled),\r\n styleFunction.CheckHiddenItem(hidden),\r\n styleFunction.checkExistsMargin(rest),\r\n styleFunction.checkExistsPadding(rest),\r\n className\r\n );\r\n\r\n return (\r\n \r\n
\r\n {props.children}
\r\n \r\n
\r\n );\r\n});\r\n\r\nexport default Slide;\r\n","/* eslint-disable no-fallthrough */\r\nimport React, { forwardRef, useContext, useId, useState } from \"react\";\r\nimport { ContextThemeProvider, styleFunction } from \"@cbmisorg/styles\";\r\nimport TabsStyle from \"./TabsStyle\";\r\nimport ErrorBoundary from \"../../_helper/errorHandeling/ErrorBoundary/ErrorBoundary\";\r\nimport { useEffect } from \"react\";\r\n\r\nconst Tabs = forwardRef((/**@type {any}*/ props, ref) => {\r\n const theTheme = useContext(ContextThemeProvider);\r\n const { classesName, style, styleSx } = TabsStyle(theTheme);\r\n const { tabsContent, currentTab = 1, activeColor = \"primary\", mode = \"nav\", sx, hidden, disabled, dir, className, id, ...rest } = props;\r\n const [tab, setTab] = useState(currentTab || 1)\r\n const classes = style();\r\n const classesSx = styleSx({ sx, activeColor, mode });\r\n const itemClasses = styleFunction.getClassName(\r\n classes?.[classesName?.tabs],\r\n classesSx?.[classesName?.tabs],\r\n classesSx?.[classesName?.sx],\r\n styleFunction.CheckDirectionItem(dir),\r\n styleFunction.CheckDisabledItem(disabled),\r\n styleFunction.CheckHiddenItem(hidden),\r\n styleFunction.checkExistsMargin(rest),\r\n styleFunction.checkExistsPadding(rest),\r\n className\r\n );\r\n const comID = id || String(useId()).slice(1, -1) + \"tab\";\r\n\r\n const handleClick = (funClick, ind) => {\r\n if (funClick) {\r\n funClick();\r\n }else{\r\n setTab(ind + 1)\r\n }\r\n };\r\n useEffect(() => {\r\n }, [props]);\r\n\r\n useEffect(() => {\r\n if (tab != currentTab) {\r\n setTab(currentTab)\r\n }\r\n }, [currentTab]);\r\n\r\n return (\r\n \r\n \r\n \r\n {tabsContent?.map((item, ind) => {\r\n return (\r\n \r\n \r\n handleClick(item?.onClick || item?.onChange || null, ind)}\r\n key={String(comID + ind + 3)}\r\n >\r\n {item?.tab || item?.tabLabel || null}\r\n \r\n \r\n );\r\n })}\r\n \r\n
\r\n\r\n \r\n {tabsContent?.[tab-1]?.content} \r\n
\r\n \r\n );\r\n});\r\n\r\nexport default Tabs;\r\n","import {\r\n StyleBuilder,\r\n styleVariables,\r\n cssKeys,\r\n mainTheme,\r\n styleFunction,\r\n} from \"@cbmisorg/styles\";\r\n\r\n\r\nexport default(objThemeInfo)=>{\r\n const cssObject = objThemeInfo?.cssObject || mainTheme?.cssObject;\r\n\r\n const classesName = {\r\n tabs: `${styleVariables?.prefixDefaultClassName}_tabs`,\r\n tab_page: `${styleVariables?.prefixDefaultClassName}_tab_page`,\r\n tab_page_contents: `${styleVariables?.prefixDefaultClassName}_tab_page_contents`,\r\n tab: `${styleVariables?.prefixDefaultClassName}_tab`,\r\n tab_input: `${styleVariables?.prefixDefaultClassName}_tab_input`,\r\n sx: `${styleVariables?.prefixDefaultClassName}_tabs_sx`,\r\n };\r\n\r\n const style = StyleBuilder({\r\n blnRandomPrefix: false,\r\n blnIsDefaultStyle: true,\r\n blnCbmisStyle: true,\r\n objStyles: {\r\n [classesName?.tabs]: {\r\n margin: \"auto\",\r\n position: \"relative\",\r\n display: \"flex\",\r\n // height: \"100%\",\r\n width: \"100%\",\r\n overflowY: \"hidden\",\r\n overflowX: \"auto\",\r\n boxSizing: cssObject?.boxSizing?.[cssKeys?.borderBox],\r\n },\r\n [classesName?.tab_page]: {\r\n margin: \"auto\",\r\n position: \"relative\",\r\n display: \"block\",\r\n height: \"100%\",\r\n width: \"100%\",\r\n overflow: \"hidden\",\r\n boxSizing: cssObject?.boxSizing?.[cssKeys?.borderBox],\r\n },\r\n [classesName?.tab_page_contents]: {\r\n maxWidth: cssObject?.size?.[cssKeys?.full],\r\n width: cssObject?.size?.[cssKeys?.full],\r\n margin: \"0 auto\",\r\n \"&*\":{\r\n opacity: 0,\r\n transition: \"opacity 0.2s, transform 0.2s\",\r\n }\r\n },\r\n [classesName?.tab]: {\r\n margin: \"auto\",\r\n position: \"relative\",\r\n display: \"flex\",\r\n boxSizing: cssObject?.boxSizing?.[cssKeys?.borderBox],\r\n alignItems: \"center\",\r\n justifyContent: \"center\",\r\n cursor: \"pointer\",\r\n userSelect: \"none\",\r\n transition: \"background 0.4s, padding-left 0.2s\",\r\n width: \"100%\",\r\n\r\n padding: `0`,\r\n marginInlineEnd: `${cssObject?.spacing?.[cssKeys?.md]}`\r\n\r\n\r\n },\r\n [classesName?.tab_input]:{\r\n display: \"none\",\r\n \"&+\":{\r\n [`.${classesName?.tab_page}`]:{\r\n transition: \"transform 0.2s\",\r\n transform: \"translateX(100%)\",\r\n }\r\n },\r\n \"&checked\":{\r\n \"&+\":{\r\n [`.${classesName?.tab_page}`]:{\r\n transform: \"translateX(0%)\",\r\n [`.${classesName?.tab_page_contents}`]:{\r\n opacity: 1,\r\n transform: \"translateY(0px)\"\r\n }\r\n }\r\n }\r\n }\r\n }\r\n },\r\n });\r\n\r\n const styleSx = StyleBuilder({\r\n blnRandomPrefix: true,\r\n blnIsDefaultStyle: false,\r\n blnCbmisStyle: true,\r\n objStyles: {\r\n [classesName?.tab_page]: {\r\n gridColumnStart: 1,\r\n gridRowStart: 2,\r\n gridColumnEnd: \"span 3\",\r\n padding: `0px ${cssObject?.spacing?.[cssKeys?.lg]}`,\r\n gridTemplateRows: `${cssObject?.size?.[cssKeys?.item_xl]} 1fr`,\r\n display: \"flex\",\r\n alignItems: \"center\",\r\n },\r\n [classesName?.tab_page_contents]: {\r\n \"&*\":{\r\n transform: `translateY(200px)`,\r\n }\r\n },\r\n [classesName?.tabs]:(props)=> {\r\n return{\r\n border:String(props?.mode)?.toLowerCase() ===\"nav\"?\"none\": `${cssObject?.size?.[cssKeys?.px]} ${cssObject?.border?.[cssKeys?.border]?.solid} ${styleFunction.checkColorReturnValue(cssObject?.color?.[cssKeys?.borderColor])}`,\r\n borderBottomColor: `${styleFunction.checkColorReturnValue(props?.activeColor || cssObject?.color?.[cssKeys?.primary])}`,\r\n background: styleFunction?.checkColorReturnValue([cssKeys?.bodyColorBgLight]),\r\n borderRadius:String(props?.mode)?.toLowerCase() !==\"pill\"?\"none\": `${cssObject?.border?.[cssKeys?.rounded]?.[cssKeys?.xl]}`,\r\n gridTemplateRows: `${cssObject?.size?.[cssKeys?.item_md]} 1fr`,\r\n }\r\n },\r\n [classesName?.tab]:(props)=> {\r\n return{\r\n minHeight: `${cssObject?.size?.[cssKeys?.item_sm]}`,\r\n fontSize: cssObject?.text?.size?.[cssKeys?.subtitle2],\r\n\r\n\r\n }\r\n },\r\n [classesName?.tab_input]:(props)=>{\r\n return{\r\n \"&checked\":{\r\n \"&+\":{\r\n [`.${classesName?.tab}`]:{\r\n background:String(props?.mode)?.toLowerCase() ===\"nav\"?\"none\": styleFunction.checkColorReturnValue(props?.activeColor || cssObject?.color?.[cssKeys?.primary]),\r\n borderBottom:String(props?.mode)?.toLowerCase() !==\"nav\"?\"none\": `${cssObject?.border?.[cssKeys?.size]?.sm} ${cssObject?.border?.[cssKeys?.border]?.solid} ${styleFunction.checkColorReturnValue(cssObject?.color?.[cssKeys?.borderColor])}`,\r\n borderBottomColor: `${styleFunction.checkColorReturnValue(props?.activeColor || cssObject?.color?.[cssKeys?.primary])}`,\r\n color: String(props?.mode)?.toLowerCase() !==\"nav\"? styleFunction.checkColorReturnValue(cssObject?.color?.[cssKeys?.light]): styleFunction.checkColorReturnValue(props?.activeColor || cssObject?.color?.[cssKeys?.primary]),\r\n borderRadius:String(props?.mode)?.toLowerCase() !==\"pill\"?\"none\": `${cssObject?.border?.[cssKeys?.rounded]?.[cssKeys?.xl]}`,\r\n fontWeight: cssObject?.text?.fontWeight?.[cssKeys?.fontWeight_md],\r\n }\r\n }\r\n }\r\n }\r\n },\r\n [classesName?.sx]: (props) => {\r\n return {\r\n ...props?.sx,\r\n };\r\n },\r\n },\r\n });\r\n\r\n\r\n\r\n return{\r\n classesName,\r\n style,\r\n styleSx,\r\n }\r\n}","import { ContextThemeProvider, styleFunction, styleVariables } from \"@cbmisorg/styles\";\r\nimport React, { Children, forwardRef, useContext, useEffect, useId, useMemo, useState } from \"react\";\r\nimport AppBarStyle from \"./AppBarStyle\";\r\nimport ErrorBoundary from \"../../_helper/errorHandeling/ErrorBoundary/ErrorBoundary\";\r\nimport Drawer from \"../Drawer/Drawer\";\r\nimport useScreenSize from \"../../_helper/hooks/useScreenSize\";\r\nimport Breadcrumbs from \"../Breadcrumbs/Breadcrumbs\";\r\n\r\nconst AppBar = forwardRef(function AppBar(/**@type {any}*/ props, ref) {\r\n const { width } = useScreenSize();\r\n\r\n const theTheme = useContext(ContextThemeProvider);\r\n const {\r\n sx,\r\n hidden,\r\n disabled,\r\n dir,\r\n className,\r\n breadcrumbs = null,\r\n blnBurgerBar = true,\r\n blnSideBarSwap = true,\r\n mode,\r\n id,\r\n outlet = null,\r\n justifyContent = \"space-between\",\r\n ...rest\r\n } = props;\r\n const [openMenuSidebar, setOpenMenuSidebar] = useState(false);\r\n const { classesName, style, styleSx } = AppBarStyle(theTheme);\r\n const classes = style();\r\n const classesSx = styleSx({ sx, justifyContent, open: openMenuSidebar, breadcrumbs: breadcrumbs ? true : false });\r\n const itemClasses = styleFunction.getClassName(\r\n classes?.[classesName?.appBar],\r\n classesSx?.[classesName?.sx],\r\n styleFunction.CheckDirectionItem(dir),\r\n styleFunction.CheckDisabledItem(disabled),\r\n styleFunction.CheckHiddenItem(hidden),\r\n styleFunction.checkExistsMargin(rest),\r\n styleFunction.checkExistsPadding(rest),\r\n className\r\n );\r\n const comID = id || useId().replace(/:/g, \"\");\r\n\r\n const getContent = useMemo(() => {\r\n let navBar = [];\r\n let sideBar = [];\r\n let bottomBar = [];\r\n // let logo = \"\";\r\n let screenSize = [\"md\", \"sm\", \"xs\"];\r\n\r\n if (width >= parseFloat(styleVariables?.xlScr)) {\r\n screenSize = [\"xl\", \"lg\", \"md\", \"sm\", \"xs\"];\r\n } else if (width <= parseFloat(styleVariables?.lgScr) && width > parseFloat(styleVariables?.mdScr)) {\r\n screenSize = [\"lg\", \"md\", \"sm\", \"xs\"];\r\n } else if (width <= parseFloat(styleVariables?.mdScr) && width > parseFloat(styleVariables?.smScr)) {\r\n screenSize = [\"md\", \"sm\", \"xs\"];\r\n } else if (width <= parseFloat(styleVariables?.smScr) && width > parseFloat(styleVariables?.xsScr)) {\r\n screenSize = [\"sm\", \"xs\"];\r\n } else {\r\n screenSize = [\"xs\"];\r\n }\r\n\r\n const checkMode = (position, item, defaultItem) => {\r\n let mode = position?.[screenSize?.[0]];\r\n if (!mode && screenSize.length > 1) {\r\n for (let index = 0; index < screenSize.length; index++) {\r\n if (position?.[screenSize?.[index]]) {\r\n mode = position?.[screenSize?.[index]];\r\n break;\r\n }\r\n }\r\n }\r\n switch (String(mode).toLowerCase()) {\r\n case \"sidebar\":\r\n sideBar.push(item);\r\n break;\r\n case \"navbar\":\r\n navBar.push(item);\r\n break;\r\n case \"bottombar\":\r\n const bottomItem = {\r\n icon: item?.props?.icon,\r\n path: item?.props?.path,\r\n label: item.props?.label || item?.props?.children,\r\n // onClick: handleDialogBottomMenu(item),\r\n };\r\n if (Number(item.props.bottomBarIndex)) {\r\n bottomBar[Number(item.props.bottomBarIndex)] = bottomItem;\r\n } else {\r\n bottomBar.push(bottomItem);\r\n }\r\n break;\r\n case \"none\":\r\n break;\r\n default:\r\n switch (String(defaultItem).toLowerCase()) {\r\n case \"sidebar\":\r\n sideBar.push(item);\r\n break;\r\n case \"navbar\":\r\n navBar.push(item);\r\n break;\r\n default:\r\n break;\r\n }\r\n break;\r\n }\r\n };\r\n Children.forEach(props?.children, (child) => {\r\n checkMode(child?.props?.position, child);\r\n });\r\n return { navBar, sideBar, bottomBar };\r\n }, [props?.children, width]);\r\n\r\n useEffect(() => {\r\n if ((width <= parseFloat(styleVariables?.smScr) && openMenuSidebar) || !getContent?.sideBar.length) {\r\n setOpenMenuSidebar(false);\r\n }else if(width > parseFloat(styleVariables?.smScr) && !openMenuSidebar && String(mode).toLowerCase()=== \"dashboard\" && getContent?.sideBar.length ){\r\n setOpenMenuSidebar(true);\r\n }\r\n },[width, mode, getContent?.sideBar])\r\n\r\n useEffect(() => {}, [sx, hidden, disabled, dir, className, mode, id, outlet, justifyContent]);\r\n\r\n return (\r\n \r\n \r\n
\r\n {!(getContent?.sideBar?.length && blnBurgerBar) ? null : openMenuSidebar ? (\r\n setOpenMenuSidebar(!openMenuSidebar)}>\r\n \r\n \r\n \r\n
\r\n ) : (\r\n setOpenMenuSidebar(true)}>\r\n \r\n \r\n \r\n
\r\n )}\r\n\r\n {getContent?.navBar}
\r\n \r\n
\r\n {mode === \"dashboard\" && (\r\n \r\n
0}\r\n eventClose={() => setOpenMenuSidebar(!openMenuSidebar)}\r\n mode={mode}\r\n key={comID + \"_Drawer\"}\r\n className={`${classes?.[classesName?.appBar_sidebarDb]} ${classesSx?.[classesName?.appBar_sidebarDb]}`}\r\n >\r\n {getContent?.sideBar} \r\n \r\n
\r\n {!breadcrumbs ? null : (\r\n
\r\n \r\n \r\n \r\n
\r\n )}\r\n {outlet}\r\n
\r\n
\r\n )}\r\n {mode !== \"dashboard\" && (\r\n 0} eventClose={() => setOpenMenuSidebar(!openMenuSidebar)} mode={mode} key={comID + \"_Drawer-d\"}>\r\n {getContent?.sideBar} \r\n \r\n )}\r\n \r\n );\r\n});\r\n\r\nexport default AppBar;\r\n","import { StyleBuilder, cssKeys, mainTheme, styleFunction, styleVariables } from \"@cbmisorg/styles\";\r\n\r\nexport default(objThemeInfo)=>{\r\n const cssObject = objThemeInfo?.cssObject || mainTheme?.cssObject;\r\n const currentBaseSize = objThemeInfo?.currentBaseSize || mainTheme?.currentBaseSize;\r\n\r\n const classesName = {\r\n appBar: `${styleVariables?.prefixDefaultClassName}_app_bar`,\r\n appBarContent: `${styleVariables?.prefixDefaultClassName}_app_bar_Content`,\r\n bar_burger: `${styleVariables?.prefixDefaultClassName}_bar_burger`,\r\n bar_close: `${styleVariables?.prefixDefaultClassName}_bar_close`,\r\n bar_1: `${styleVariables?.prefixDefaultClassName}_bar_1`,\r\n bar_2: `${styleVariables?.prefixDefaultClassName}_bar_2`,\r\n bar_3: `${styleVariables?.prefixDefaultClassName}_bar_3`,\r\n\r\n appBar_sidebarDbOutlet: `${styleVariables?.prefixDefaultClassName}_app_bar_sidebarDbOutlet`,\r\n appBar_sidebarDb: `${styleVariables?.prefixDefaultClassName}_app_bar_sidebarDb`,\r\n appBar_outlet: `${styleVariables?.prefixDefaultClassName}_app_bar_outlet`,\r\n drawer: `${styleVariables?.prefixDefaultClassName}_drawer`,\r\n appBar_breadcrumbs: `${styleVariables?.prefixDefaultClassName}_app_bar_breadcrumbs`,\r\n\r\n\r\n sx:`${styleVariables?.prefixDefaultClassName}_appBar_sx`\r\n }\r\n const getWidth=()=>{\r\n if(open){\r\n return{\r\n xs:{\r\n minWidth: \"100vw\",\r\n },\r\n sm:{\r\n minWidth: \"70vw\",\r\n },\r\n md:{\r\n minWidth: \"80vw\",\r\n },\r\n lg:{\r\n minWidth: \"83.8vw\",\r\n },\r\n xl:{\r\n minWidth: \"90vw\",\r\n },\r\n }\r\n }\r\n }\r\n const style = StyleBuilder({\r\n blnRandomPrefix: false,\r\n blnIsDefaultStyle: true,\r\n blnCbmisStyle: true,\r\n objStyles: {\r\n [classesName?.appBar]:{\r\n transition: \"top 300ms cubic-bezier(0.4, 0, 0.2, 1) 0ms\",\r\n display: \"flex\",\r\n flexDirection: \"row\",\r\n alignItems: \"center\",\r\n justifyContent:\"space-between\",\r\n boxSizing: \"border-box\",\r\n zIndex: 1200,\r\n // boxShadow: cssObject?.boxShadow?.[cssKeys?.outline],\r\n overflowY: \"hidden\",\r\n position: \"sticky\",\r\n top:\"0px\",\r\n left:\"0px\",\r\n right:\"0px\",\r\n background:\"#f9fafb\",\r\n width:\"100%\",\r\n height: cssObject?.size?.[cssKeys?.item_md],\r\n margin:\"0px\",\r\n padding:`0px ${cssObject?.spacing?.[cssKeys?.xl]}`,\r\n sm:{\r\n padding:`0px ${cssObject?.spacing?.[cssKeys?.sm]}`,\r\n }\r\n },\r\n [classesName?.appBarContent]:{\r\n display: \"flex\",\r\n flexDirection: \"row\",\r\n alignItems: \"center\",\r\n justifyContent:\"space-between\",\r\n boxSizing: \"border-box\",\r\n zIndex: 1,\r\n overflowY: \"hidden\",\r\n position: \"relative\",\r\n top:\"0px\",\r\n left:\"0px\",\r\n right:\"0px\",\r\n width:\"100%\",\r\n height: cssObject?.size?.[cssKeys?.item_md],\r\n margin:\"0px\",\r\n },\r\n\r\n [classesName?.appBar_sidebarDbOutlet]:{\r\n display:\"flex\",\r\n width:\"100vw\",\r\n position: \"relative\",\r\n padding:\"0\",\r\n margin:\"0 auto\",\r\n overflow:\"hidden\",\r\n minHeight:\"calc(100vh - 68px)\",\r\n\r\n },\r\n [classesName?.appBar_sidebarDb]:{\r\n [`.${classesName?.drawer}`]:{\r\n position: \"sticky\",\r\n height:\"calc(100vh - 68px)\",\r\n },\r\n },\r\n [classesName?.appBar_outlet]:{\r\n position: \"relative\",\r\n minHeight:\"100%\",\r\n width:\"max-content\",\r\n margin: \"0 auto\",\r\n marginInlineEnd: 0,\r\n padding:\"0px\",\r\n ...getWidth(),\r\n },\r\n },\r\n });\r\n\r\n const styleSx = StyleBuilder({\r\n blnRandomPrefix: true,\r\n blnIsDefaultStyle: false,\r\n blnCbmisStyle: true,\r\n objStyles:{\r\n [classesName?.appBarContent]: (props) => {\r\n return {\r\n width: props?.open? \"calc(100% - 30px)\": \"100%\"\r\n };\r\n },\r\n [classesName?.bar_burger]: (props) =>{\r\n return{\r\n display: \"block\",\r\n position: \"relative\",\r\n cursor: \"pointer\",\r\n zIndex: \"2\",\r\n transition: \"all 0.7s ease\",\r\n margin:0,\r\n padding:0,\r\n width: `${currentBaseSize * 7}rem`,\r\n height: `${currentBaseSize * 5}rem`,\r\n color: cssObject?.color?.[cssKeys?.bodyColor],\r\n \"span\":{\r\n background: cssObject?.color?.[cssKeys?.currentColor],\r\n position: \"absolute\",\r\n width: \"100%\",\r\n height: \"20%\",\r\n borderRadius: cssObject?.border?.[cssKeys?.rounded]?.sm,\r\n transition: props.open? \".4s top, .4s bottom, .4s .4s transform\": \".4s .4s top, .4s .4s bottom, .3s transform\"\r\n },\r\n [`.${classesName?.bar_1}`]:{\r\n // ...(props.open?{\r\n // top: \"40%\",\r\n // transform: \"rotate(45deg)\"\r\n // }:{\r\n top: 0\r\n // })\r\n },\r\n [`.${classesName?.bar_2}`]:{\r\n // ...(props.open?{\r\n // opacity: \"0 \",\r\n // transition: \"opacity .1s .4s \",\r\n // }:{\r\n top: \"40%\",\r\n opacity: \"1\",\r\n transition: \"opacity .1s .4s\"\r\n // }),\r\n },\r\n [`.${classesName?.bar_3}`]:{\r\n // ...(props.open?{\r\n // bottom: \"40%\",\r\n // transform: \"rotate(-45deg)\"\r\n // }:{\r\n bottom: 0\r\n // })\r\n },\r\n }\r\n },\r\n [classesName?.appBar_outlet]: (props) =>{\r\n return{\r\n position: \"relative\",\r\n minHeight:\"100%\",\r\n width: props.open? \"auto\" :\"100vw\",\r\n marginInlineEnd: 0,\r\n padding:0,\r\n \r\n }\r\n },\r\n\r\n\r\n [classesName?.appBar_sidebarDb]:{\r\n [`.${classesName?.drawer}`]:{\r\n position: \"sticky\",\r\n height:\"calc(100vh - 68px)\",\r\n },\r\n },\r\n [classesName?.appBar_breadcrumbs]:(props)=>{\r\n if(props?.breadcrumbs){\r\n return{\r\n // borderBottom: `1px solid #ccc`,\r\n background: styleFunction.checkColorReturnValue(cssObject?.color?.[cssKeys?.bodyColorBgLight]),\r\n marginInlineEnd: 0,\r\n width: \"100%\",\r\n display:\"flex\",\r\n position:\"relative\",\r\n ...getWidth()\r\n }\r\n }\r\n },\r\n [classesName?.sx]: (props) => {\r\n return {\r\n ...props?.sx,\r\n justifyContent:props?.justifyContent,\r\n };\r\n },\r\n },\r\n });\r\n\r\n return{\r\n classesName,\r\n style,\r\n styleSx\r\n }\r\n}","\r\nimport { StyleBuilder, cssKeys, mainTheme, styleVariables } from \"@cbmisorg/styles\";\r\n\r\nexport default(objThemeInfo)=>{\r\n const cssObject = objThemeInfo?.cssObject || mainTheme?.cssObject;\r\n const currentBaseSize = objThemeInfo?.currentBaseSize || mainTheme?.currentBaseSize;\r\n\r\n const classesName = {\r\n groupBar: `${styleVariables?.prefixDefaultClassName}_group_bar`,\r\n sx:`${styleVariables?.prefixDefaultClassName}_groupBar_sx`\r\n }\r\n const style = StyleBuilder({\r\n blnRandomPrefix: false,\r\n blnIsDefaultStyle: true,\r\n blnCbmisStyle: true,\r\n objStyles: {\r\n [classesName?.groupBar]:{\r\n transition: \"top 300ms cubic-bezier(0.4, 0, 0.2, 1) 0ms\",\r\n position: \"relative\",\r\n width: \"auto\",\r\n margin: \"0px\",\r\n display: \"flex\",\r\n flexWrap: \"wrap\",\r\n boxSizing: \"inherit\",\r\n alignItems: \"center\",\r\n textTransform: \"capitalize\",\r\n listStyle: \"none\",\r\n justifyContent: \"flex-start\",\r\n background: \"transparent\",\r\n },\r\n },\r\n });\r\n\r\n const styleSx = StyleBuilder({\r\n blnRandomPrefix: true,\r\n blnIsDefaultStyle: false,\r\n blnCbmisStyle: true,\r\n objStyles:{\r\n [classesName?.sx]: (props) => {\r\n return {\r\n ...props?.sx,\r\n };\r\n },\r\n },\r\n });\r\n\r\n return{\r\n classesName,\r\n style,\r\n styleSx\r\n }\r\n}","import React, { forwardRef, useContext, useId, useRef, useState } from \"react\";\r\nimport NavStyle from \"./NavStyle\";\r\nimport { ContextThemeProvider, styleFunction } from \"@cbmisorg/styles\";\r\nimport { Icon } from \"@cbmisorg/icons\";\r\nimport Menu from \"../Menu/Menu\";\r\n\r\nconst Nav = forwardRef((/**@type {any}*/ props, ref) => {\r\n const { label, to, replace, menu, state, headItem, footerItem,blnCloseOutMenuClick, sx, id, hidden, disabled, dir, className, onClick, eventNavClick, ...rest } = props;\r\n let cmp_ID = id || useId().replace(/:/g, \"\");\r\n const [open, setOpen] = useState(false);\r\n\r\n const theTheme = useContext(ContextThemeProvider);\r\n const { classesName, style, styleSx } = NavStyle(theTheme);\r\n const classes = style();\r\n const classesSx = styleSx({ sx, open, hasContent: menu?.length ? true : false });\r\n\r\n const handleClicked = (event) => {\r\n if (menu && menu?.length) {\r\n setOpen(!open);\r\n }\r\n if (onClick) {\r\n onClick(event);\r\n }\r\n };\r\n\r\n return (\r\n \r\n
\r\n {!headItem ? null :
{headItem}
}\r\n
\r\n {label || props?.children}\r\n
\r\n {!footerItem && !menu ? null : (\r\n
\r\n {footerItem ? footerItem : menu ? : null}\r\n
\r\n )}\r\n
\r\n
setOpen(false)} blnCloseOutMenuClick={blnCloseOutMenuClick} className={classesSx?.[classesName?.nav_menu]}>\r\n {menu}
\r\n \r\n
\r\n );\r\n});\r\n\r\nexport default Nav;\r\n\r\n// // if(to){\r\n// // if(typeof window !==\"undefined\"){\r\n// // if(replace){\r\n// // window.history.replaceState(state, \"\", path);\r\n// // }else{\r\n// // window.history.pushState(state, \"\", path);\r\n// // }\r\n// // }\r\n// // }\r\n// console.log(open);\r\n// // event.preventDefault()\r\n// // if(open){\r\n// // }else{\r\n// // if(menu?.length){\r\n// // setOpen(true);\r\n// // }\r\n// // }\r\n\r\n// alert(cmp_ID)\r\n// if(!open?.cmp_ID && menu && menu?.length>0){\r\n// setOpen(true);\r\n// }else{\r\n// setOpen({cmp_ID: !open?.cmp_ID});\r\n// }\r\n","import {\r\n StyleBuilder,\r\n styleVariables,\r\n cssKeys,\r\n mainTheme,\r\n styleFunction,\r\n} from \"@cbmisorg/styles\";\r\n\r\nexport default(objThemeInfo)=>{\r\n const cssObject = objThemeInfo?.cssObject || mainTheme?.cssObject;\r\n const currentBaseSize = objThemeInfo?.currentBaseSize || mainTheme?.currentBaseSize;\r\n\r\n const classesName = {\r\n nav: `${styleVariables?.prefixDefaultClassName}_nav_item`,\r\n nav_menu: `${styleVariables?.prefixDefaultClassName}_nav_menu`,\r\n nav_nav_container: `${styleVariables?.prefixDefaultClassName}_nav_nav_container`,\r\n nav_item_head: `${styleVariables?.prefixDefaultClassName}_nav_item_head`,\r\n nav_item_item_content: `${styleVariables?.prefixDefaultClassName}_nav_item_item_content`,\r\n nav_item_footer: `${styleVariables?.prefixDefaultClassName}_nav_item_footer`,\r\n \r\n sx:`${styleVariables?.prefixDefaultClassName}_nav_sx`\r\n };\r\n\r\n const style = StyleBuilder({\r\n blnRandomPrefix: false,\r\n blnIsDefaultStyle: true,\r\n blnCbmisStyle: true,\r\n objStyles: {\r\n [classesName?.nav_nav_container]: {\r\n margin: \"auto\",\r\n cursor: \"pointer\",\r\n position:\"relative\",\r\n textAlign:\"center\",\r\n display: cssObject?.display?.[cssKeys?.block],\r\n width:\"100%\",\r\n flexBasis:\"1\"\r\n\r\n },\r\n [classesName?.nav]: {\r\n transition: \"all ease-in-out 350ms\",\r\n margin: \"auto\",\r\n cursor: \"pointer\",\r\n // listStyle: \"none\",\r\n // display: \"flex\",\r\n // justifyContent:\"start\",\r\n // alignContent:\"center\",\r\n position:\"relative\",\r\n textAlign:\"center\",\r\n display: cssObject?.display?.[cssKeys?.flex],\r\n flex:1,\r\n justifyContent:\"space-between\",\r\n alignItems: \"flex-start\",\r\n width:\"max-content\",\r\n\r\n\r\n },\r\n [classesName?.nav_item_head]:{\r\n justifyContent: \"center\",\r\n textAlign: \"center\",\r\n // padding:cssObject?.spacing?.[cssKeys?.xs],\r\n background: \"transparent\",\r\n display: \"flex\",\r\n width: \"max-content\",\r\n margin:cssObject?.spacing?.[cssKeys?.xs],\r\n },\r\n [classesName?.nav_item_item_content]:{\r\n textAlign: \"start\",\r\n background: \"transparent\",\r\n // padding:cssObject?.spacing?.[cssKeys?.xs],\r\n display: \"flex\",\r\n alignItems: \"center\",\r\n minWidth: \"max-content\",\r\n justifyContent: \"flex-start\",\r\n width:\"100%\"\r\n },\r\n [classesName?.nav_item_footer]:{\r\n display: \"flex\",\r\n alignSelf: \"center\",\r\n justifyContent: \"center\",\r\n textAlign: \"center\",\r\n width: \"max-content\",\r\n margin:cssObject?.spacing?.[cssKeys?.xs],\r\n background: \"transparent\",\r\n },\r\n },\r\n });\r\n\r\n const styleSx = StyleBuilder({\r\n blnRandomPrefix: true,\r\n blnIsDefaultStyle: false,\r\n blnCbmisStyle: true,\r\n objStyles: {\r\n [classesName?.nav]: (props) => {\r\n return{\r\n padding: `${cssObject?.spacing?.[cssKeys?.xs]}`,\r\n minHeight: `${cssObject?.size?.[cssKeys?.item_sm]}`,\r\n \"&hover\":{\r\n background: cssObject?.color?.[cssKeys?.bodyColorLight],\r\n cursor:\"pointer\"\r\n }\r\n }\r\n },\r\n [classesName?.nav_menu]: (props) => {\r\n return{\r\n boxSizing: \"border-content\",\r\n minWidth: `max-content`,\r\n maxHeight: \"75%\",\r\n width:\"100%\",\r\n padding: props?.hasContent?`${cssObject?.spacing?.[cssKeys?.xs]}`: \"0px\",\r\n [`.${classesName?.nav}`]:{\r\n minWidth:\"90% !important\"\r\n }\r\n\r\n }\r\n },\r\n [classesName?.sx]: (props) => {\r\n return {\r\n ...props?.sx\r\n };\r\n },\r\n },\r\n });\r\n\r\n\r\n return{\r\n classesName,\r\n style,\r\n styleSx,\r\n }\r\n}","import { StyleBuilder, cssKeys, mainTheme, styleFunction, styleVariables } from \"@cbmisorg/styles\";\r\n\r\n export default(objThemeInfo)=>{\r\n const cssObject = objThemeInfo?.cssObject || mainTheme?.cssObject;\r\n \r\n const classesName = {\r\n accordion_row: `${styleVariables?.prefixDefaultClassName}_accordion_row`,\r\n accordion_col: `${styleVariables?.prefixDefaultClassName}_accordion_col`,\r\n accordion_tabs: `${styleVariables?.prefixDefaultClassName}_accordion_tabs`,\r\n accordion_tab: `${styleVariables?.prefixDefaultClassName}_accordion_tab`,\r\n accordion_tab_summary_label: `${styleVariables?.prefixDefaultClassName}_accordion_tab_summary_label`,\r\n accordion_tab_summary_label_content: `${styleVariables?.prefixDefaultClassName}_accordion_tab_summary_label_content`,\r\n accordion_tab_summary_label_arrowIcon: `${styleVariables?.prefixDefaultClassName}_accordion_tab_summary_label_arrowIcon`,\r\n accordion_tab_summary_icon: `${styleVariables?.prefixDefaultClassName}_accordion_tab_summary_icon`,\r\n accordion_tab_summary_icon_arrowIcon: `${styleVariables?.prefixDefaultClassName}_accordion_tab_summary_icon_arrowIcon`,\r\n accordion_tab_summary_label_content_children: `${styleVariables?.prefixDefaultClassName}_accordion_tab_summary_label_content_children`,\r\n accordion_tab_summary_input: `${styleVariables?.prefixDefaultClassName}_accordion_tab_summary_input`,\r\n accordion_tab_details: `${styleVariables?.prefixDefaultClassName}_accordion_tab_details`,\r\n accordion_tab_summary_input_dontOpen: `${styleVariables?.prefixDefaultClassName}_accordion_tab_summary_input_dontOpen`,\r\n accordion_horizontal_tabs: `${styleVariables?.prefixDefaultClassName}_accordion_horizontal_tabs`,\r\n sx: `${styleVariables?.prefixDefaultClassName}_accordion_sx`,\r\n };\r\n \r\n const style = StyleBuilder({\r\n blnRandomPrefix: false,\r\n blnIsDefaultStyle: true,\r\n blnCbmisStyle: true,\r\n objStyles: {\r\n [classesName?.accordion_row]:{\r\n width: \"100%\",\r\n display:\"flex\",\r\n },\r\n [classesName?.accordion_col]:{\r\n width: \"100%\",\r\n display:\"block\",\r\n },\r\n [classesName?.accordion_tabs]:{\r\n overflow: \"hidden\",\r\n position: \"relative\",\r\n padding: cssObject?.spacing?.xs,\r\n backgroundColor: \"transparent\",\r\n },\r\n [classesName?.accordion_tab]:{\r\n borderRadius: 0,\r\n width:\"auto\",\r\n overflow: \"hidden\",\r\n position: \"relative\",\r\n background: \"transparent\",\r\n cursor: \"pointer\",\r\n display:\"block\",\r\n backgroundColor:cssObject?.color?.[cssKeys?.white]\r\n\r\n },\r\n [classesName?.accordion_tab_summary_label]:{\r\n display: \"flex\",\r\n justifyContent: \"space-between\",\r\n verticalAlign: \"middle\",\r\n position: \"relative\",\r\n cursor: \"pointer\",\r\n // \"&before\":{\r\n // content: \"&rangle\",\r\n // textAlign: \"end\",\r\n // transition: \"all .35s\",\r\n // transform: \"rotate(90deg)\",\r\n // position: \"absolute\",\r\n // right:\"0\"\r\n // }\r\n },\r\n [classesName?.accordion_tab_summary_label_content]:{\r\n width: \"100%\",\r\n display: \"flex\",\r\n },\r\n [classesName?.accordion_tab_summary_label_arrowIcon]:{\r\n \"&after\":{\r\n content: \"\",\r\n width: 0,\r\n height: 0,\r\n padding: 0,\r\n }\r\n },\r\n [classesName?.accordion_tab_summary_icon]:{\r\n margin: \"auto\",\r\n },\r\n [classesName?.accordion_tab_summary_icon_arrowIcon]:{\r\n transition: \"transform .5s\"\r\n },\r\n [classesName?.accordion_tab_summary_label_content_children]:{\r\n width: \"99%\",\r\n margin: \"auto\",\r\n },\r\n [classesName?.accordion_tab_summary_input]:{\r\n position: \"absolute\",\r\n top: 0,\r\n left: 0,\r\n width: \"100%\",\r\n minHeight: cssObject?.size?.[cssKeys?.item_lg],\r\n background: \"#fff\",\r\n cursor: \"pointer\",\r\n opacity: 0,\r\n // zIndex:1,\r\n \"&checked\":{\r\n \"&~\":{\r\n [`.${classesName?.accordion_tab_details}`]:{\r\n // zIndex: 2,\r\n visibility: \"visible\",\r\n opacity: \"1\",\r\n \"&*\":{\r\n // zIndex: 2,\r\n }\r\n }},\r\n \"&+\":{\r\n [`.${classesName?.accordion_tab_summary_label}`]:{\r\n \"&after\":{\r\n marginTop: cssObject?.spacing?.sm,\r\n transform: \"rotate(270deg) translateY(-50%)\",\r\n },\r\n [`.${classesName?.accordion_tab_summary_icon_arrowIcon}`]:{\r\n transform: \"rotateZ(180deg)\",\r\n \r\n }\r\n }\r\n }\r\n }\r\n },\r\n [classesName?.accordion_tab_summary_input_dontOpen]:{\r\n pointerEvents:\"none\",\r\n },\r\n [classesName?.accordion_tab_details]:{\r\n display: \"none\",\r\n // maxHeight: \"0px\",\r\n position: \"relative\",\r\n transition: \"height 1s\"\r\n },\r\n [classesName?.accordion_horizontal_tabs]:{\r\n display: \"flex\",\r\n flexWrap: \"nowrap\",\r\n overflow: \"hidden\",\r\n position: \"relative\",\r\n width: \"auto\",\r\n [`.${classesName?.accordion_tab}`]:{\r\n display: \"flex\",\r\n flexWrap: \"nowrap\",\r\n position: \"relative\",\r\n transition: \"all .5s\",\r\n height: \"auto\",\r\n width: \"auto\",\r\n },\r\n [`.${classesName?.accordion_tab_details}`]:{\r\n padding:`0 ${cssObject?.spacing?.xs}`,\r\n color:cssObject?.color?.bodyColor,\r\n },\r\n [`.${classesName?.accordion_tab_summary_input}`]:{\r\n \"&checked\":{\r\n \"&~\":{\r\n [`.${classesName?.accordion_tab_details}`]:{\r\n // width: \"auto\",\r\n // minWidth: \"10vw\",\r\n // maxWidth: \"75vw\",\r\n // visibility: \"visible\",\r\n // opacity: \"1\",\r\n // maxHeight: \"100%\",\r\n // padding: `0 ${cssObject?.spacing?.xs}`,\r\n // boxShadow: \"0 0 0 0 transparent\",\r\n // zIndex: \"2\",\r\n // overflowY: \"auto\",\r\n \r\n\r\n padding: cssObject?.spacing?.xs,\r\n boxShadow: cssObject?.boxShadow?.sm,\r\n },\r\n },\r\n \"&+\":{\r\n [`.${classesName?.accordion_tab_summary_label}`]:{\r\n \"&after\":{\r\n marginTop: \"0\",\r\n transform: \"rotate(180deg) translateY(-100%)\",\r\n }\r\n },\r\n }\r\n }\r\n },\r\n [`.${classesName?.accordion_tab_summary_label}`]:{\r\n maxWidth: \"500px !important\",\r\n minWidth: \"110px !important\",\r\n \"&after\":{\r\n transform: \"rotate(0deg)\"\r\n }\r\n }\r\n }\r\n },\r\n });\r\n \r\n const styleSx = StyleBuilder({\r\n blnRandomPrefix: true,\r\n blnIsDefaultStyle: false,\r\n blnCbmisStyle: true,\r\n objStyles:{\r\n [classesName?.sx]: (props) => {\r\n if(props?.color){\r\n return{\r\n color: props?.color || \"#000\",\r\n ...props?.sx\r\n }\r\n }\r\n return props?.sx;\r\n },\r\n \r\n },\r\n });\r\n \r\n const styleTabSx = StyleBuilder({\r\n blnRandomPrefix: true,\r\n blnIsDefaultStyle: false,\r\n blnCbmisStyle: true,\r\n className:\"\",\r\n objStyles:{\r\n [classesName?.sx]: (props) => {\r\n if(props?.color){\r\n return{\r\n color: props?.color || \"#000\",\r\n ...props?.sx\r\n }\r\n }\r\n return props?.sx;\r\n },\r\n \r\n },\r\n });\r\n \r\n \r\n const styleDetailsSx = StyleBuilder({\r\n blnRandomPrefix: true,\r\n blnIsDefaultStyle: false,\r\n blnCbmisStyle: true,\r\n objStyles:{\r\n [classesName?.sx]: (props) => {\r\n const objCss={}\r\n if(props?.color){\r\n objCss.color= props?.color || \"#000\";\r\n }\r\n if(props?.openDetails){\r\n objCss.display= \"block\";\r\n }\r\n return {...props?.sx, ...objCss};\r\n },\r\n },\r\n });\r\n \r\n const styleSummarySx = StyleBuilder({\r\n blnRandomPrefix: true,\r\n blnIsDefaultStyle: false,\r\n blnCbmisStyle: true,\r\n objStyles:{\r\n [classesName?.accordion_tab_summary_label]:{\r\n padding: `${cssObject?.spacing?.xs} ${cssObject?.spacing?.xs}`,\r\n fontWeight: cssObject?.text?.fontWeight?.fontWeight_lg,\r\n fontSize:cssObject?.text?.size?.subtitle2,\r\n minHeight: cssObject?.size?.[cssKeys?.item_lg],\r\n borderBottom: `${cssObject?.size?.[cssKeys?.border_xs]} ${cssObject?.border?.[cssKeys?.border]?.solid} ${styleFunction.checkColorReturnValue(cssObject?.color?.[cssKeys?.currentColor])}`,\r\n },\r\n [classesName?.accordion_tab_summary_label_content]:{\r\n maxWidth: \"90%\",\r\n minHeight: cssObject?.size?.[cssKeys?.item_sm],\r\n display: \"flex\",\r\n },\r\n [classesName?.accordion_tab_summary_icon_arrowIcon]:{\r\n fontSize:cssObject?.text?.size?.h6,\r\n },\r\n [classesName?.sx]: (props) => {\r\n if(props?.color){\r\n return{\r\n color:styleFunction?.checkColorReturnValue(cssObject?.color?.[cssKeys?.bodyColor]),\r\n ...props?.sx\r\n }\r\n }\r\n return props?.sx;\r\n },\r\n },\r\n });\r\n \r\n return{\r\n classesName,\r\n style,\r\n styleSx,\r\n styleTabSx,\r\n styleDetailsSx,\r\n styleSummarySx\r\n }\r\n }","import React, { forwardRef, useContext, useId } from \"react\";\r\nimport { ContextThemeProvider, styleFunction } from \"@cbmisorg/styles\";\r\nimport AccordionStyle from \"./AccordionStyle\";\r\n\r\nconst Accordion = forwardRef((/**@type {any}*/props, ref) => {\r\n const { children, ariaControl, sx, hidden, disabled, dir, className, id,mode, ...rest } = props;\r\n const theTheme = useContext(ContextThemeProvider);\r\n const {classesName, style, styleSx} = AccordionStyle(theTheme);\r\n const classes = style();\r\n const classesSx = styleSx({sx,mode});\r\n const comID = id || String(useId()).slice(1,-1) + \"_accordion\";\r\n\r\n const itemClasses = styleFunction.getClassName(classes?.[classesName?.accordion_tabs], classesSx?.[classesName?.sx], styleFunction.CheckDirectionItem(dir),styleFunction.CheckDisabledItem(disabled), styleFunction.CheckHiddenItem(hidden),styleFunction.checkExistsMargin(rest),styleFunction.checkExistsPadding(rest), className);\r\n\r\n return (\r\n \r\n
\r\n
\r\n {children}\r\n
\r\n
\r\n
\r\n );\r\n});\r\n\r\nexport default Accordion;\r\n","import React, { forwardRef, useContext, useId, useState } from \"react\";\r\nimport { ContextThemeProvider, styleFunction } from \"@cbmisorg/styles\";\r\nimport AccordionStyle from \"./AccordionStyle\";\r\n\r\nconst AccordionTab = forwardRef((/**@type {any}*/ props, ref) => {\r\n const { children, open = false, blnOpenOne = false, sx, hidden, disabled, id, dir, className, ...rest } = props;\r\n const theTheme = useContext(ContextThemeProvider);\r\n const { classesName, style, styleTabSx } = AccordionStyle(theTheme);\r\n const classes = style();\r\n const classesSx = styleTabSx({ sx });\r\n const comID = id || String(useId()).slice(1, -1);\r\n const [openDetails, setOpenDetails] = useState(open);\r\n\r\n const itemClasses = styleFunction.getClassName(\r\n classes?.[classesName?.accordion_tab],\r\n classesSx?.[classesName?.sx],\r\n styleFunction.CheckDirectionItem(dir),\r\n styleFunction.CheckDisabledItem(disabled),\r\n styleFunction.CheckHiddenItem(hidden),\r\n styleFunction.checkExistsMargin(rest),\r\n styleFunction.checkExistsPadding(rest),\r\n className\r\n );\r\n\r\n const handleChangeInput = (event) => {\r\n setOpenDetails(event?.target?.checked);\r\n };\r\n return (\r\n \r\n {!children[0] ? null : React.cloneElement(children[0], { open: openDetails, blnOpenOne: blnOpenOne, tabID: comID, handleChangeInput: handleChangeInput })}\r\n {!children[1] ? null : React.cloneElement(children[1], { openDetails: openDetails, tabID: comID, })}\r\n
\r\n );\r\n});\r\n\r\nexport default AccordionTab;\r\n","import React, { forwardRef, useContext, useEffect, useId } from \"react\";\r\nimport { ContextThemeProvider, styleFunction } from \"@cbmisorg/styles\";\r\nimport { Icon } from \"@cbmisorg/icons\";\r\nimport AccordionStyle from \"./AccordionStyle\";\r\n\r\nconst AccordionSummary = forwardRef((/**@type {any}*/ props, ref) => {\r\n const {\r\n id,\r\n children,\r\n onChange,\r\n handleChangeInput,\r\n inputRef,\r\n expandIcon,\r\n tabID,\r\n open = false,\r\n blnOpenOne = false,\r\n arrowIcon = \"expandMore\",\r\n iconSize,\r\n sx,\r\n hidden,\r\n disabled,\r\n dir,\r\n className,\r\n ...rest\r\n } = props;\r\n const theTheme = useContext(ContextThemeProvider);\r\n const { classesName, style, styleSummarySx } = AccordionStyle(theTheme);\r\n const classes = style();\r\n const classesSx = styleSummarySx({ sx });\r\n const comID = tabID ? tabID + \"_inputAccordion\" : id || String(useId()).slice(1, -1) + \"accordion\";\r\n\r\n const itemClasses = styleFunction.getClassName(\r\n classes?.[classesName?.accordion_tab_summary_label],\r\n classesSx?.[classesName?.accordion_tab_summary_label],\r\n classesSx?.[classesName?.sx],\r\n styleFunction.CheckDirectionItem(dir),\r\n styleFunction.CheckDisabledItem(disabled),\r\n styleFunction.CheckHiddenItem(hidden),\r\n styleFunction.checkExistsMargin(rest),\r\n styleFunction.checkExistsPadding(rest),\r\n className\r\n );\r\n\r\n const handleChangeInputSummary = (event) => {\r\n if (handleChangeInput) {\r\n handleChangeInput(event);\r\n }\r\n if (onChange) {\r\n onChange(event);\r\n }\r\n };\r\n return (\r\n \r\n \r\n \r\n \r\n {expandIcon && (\r\n \r\n {expandIcon}\r\n \r\n )}\r\n \r\n {children}\r\n \r\n \r\n {!arrowIcon ? null : (\r\n \r\n \r\n \r\n )}\r\n \r\n \r\n );\r\n});\r\n\r\nexport default AccordionSummary;\r\n","import React, { forwardRef, useContext } from \"react\";\r\nimport { ContextThemeProvider, styleFunction } from \"@cbmisorg/styles\";\r\nimport AccordionStyle from \"./AccordionStyle\";\r\n\r\nconst AccordionDetails = forwardRef((/**@type {any}*/ props, ref) => {\r\n const { blnAddToDomClose = false, openDetails=false, onClick, tabID, children, hidden, sx, disabled, dir, className, ...rest } = props;\r\n const theTheme = useContext(ContextThemeProvider);\r\n const { classesName, style, styleDetailsSx } = AccordionStyle(theTheme);\r\n const classes = style();\r\n const classesSx = styleDetailsSx({ sx, openDetails: openDetails });\r\n\r\n\r\n const itemClasses = styleFunction.getClassName(\r\n classes?.[classesName?.accordion_tab_details],\r\n classesSx?.[classesName?.sx],\r\n styleFunction.CheckDirectionItem(dir),\r\n styleFunction.CheckDisabledItem(disabled),\r\n styleFunction.CheckHiddenItem(hidden),\r\n styleFunction.checkExistsMargin(rest),\r\n styleFunction.checkExistsPadding(rest),\r\n className\r\n );\r\n\r\n\r\n return (\r\n \r\n {blnAddToDomClose || openDetails? children : null}\r\n
\r\n );\r\n});\r\n\r\nexport default AccordionDetails;\r\n","import {\r\n StyleBuilder,\r\n styleVariables,\r\n cssKeys,\r\n mainTheme,\r\n} from \"@cbmisorg/styles\";\r\n\r\nexport default(objThemeInfo)=>{\r\n const cssObject = objThemeInfo?.cssObject || mainTheme?.cssObject;\r\n\r\n const classesName = {\r\n card_container: `${styleVariables?.prefixDefaultClassName}_card_container`,\r\n card: `${styleVariables?.prefixDefaultClassName}_card`,\r\n card_have_back: `${styleVariables?.prefixDefaultClassName}_card_have_back`,\r\n card_image: `${styleVariables?.prefixDefaultClassName}_card_image`,\r\n card_frame: `${styleVariables?.prefixDefaultClassName}_card_frame`,\r\n card_image_hover: `${styleVariables?.prefixDefaultClassName}_card_image_hover`,\r\n card_frame_bg: `${styleVariables?.prefixDefaultClassName}_card_frame_bg`,\r\n card_frame_content: `${styleVariables?.prefixDefaultClassName}_card_frame_content`,\r\n card_front: `${styleVariables?.prefixDefaultClassName}_card_front`,\r\n card_back: `${styleVariables?.prefixDefaultClassName}_card_back`,\r\n card_content: `${styleVariables?.prefixDefaultClassName}_card_content`,\r\n card_details: `${styleVariables?.prefixDefaultClassName}_card_details`,\r\n\r\n sx: `${styleVariables?.prefixDefaultClassName}_card_sx`,\r\n };\r\n\r\n const style = StyleBuilder({\r\n blnRandomPrefix: false,\r\n blnIsDefaultStyle: true,\r\n blnCbmisStyle: true,\r\n objStyles: {\r\n [classesName?.card_container]: {\r\n display: \"flex\",\r\n boxOrient: \"horizontal\",\r\n WebkitBoxDirection :\"normal\",\r\n boxPack: \"center\",\r\n WebkitBoxPack: \"center\",\r\n MozBoxPack: \"center\",\r\n justifyContent: \"center\",\r\n width:\"100%\",\r\n height:\"100%\",\r\n margin: \"auto\",\r\n padding: 0,\r\n position: \"relative\",\r\n },\r\n [classesName?.card]:{\r\n width: \"100%\",\r\n borderRadius: \"5px\",\r\n position: \"relative\",\r\n transition: \"transform 0.5s\",\r\n transformStyle: \"preserve-3d\",\r\n margin: \"auto\",\r\n padding: 0,\r\n maxHeight: \"500vh\",\r\n display: \"block\",\r\n [`.${classesName?.card_front}`]:{\r\n position:\"relative\",\r\n width: \"100%\",\r\n top: 0,\r\n left: 0,\r\n backfaceVisibility: \"hidden\",\r\n MozBackfaceVisibility: \"hidden\",\r\n WebkitBackfaceVisibility: \"hidden\",\r\n transition: \"all 0.5s\",\r\n zIndex: 3,\r\n transform: \"rotateY( 0deg )\",\r\n boxShadow: cssObject?.boxShadow?.[cssKeys?.sm]\r\n },\r\n [`.${classesName?.card_back}`]:{\r\n position:\"absolute\",\r\n width: \"100%\",\r\n top: 0,\r\n left: 0,\r\n backfaceVisibility: \"hidden\",\r\n MozBackfaceVisibility: \"hidden\",\r\n WebkitBackfaceVisibility: \"hidden\",\r\n transition: \"all 0.5s\",\r\n zIndex:2,\r\n transform: \"rotateY( 180deg )\",\r\n boxShadow: cssObject?.boxShadow?.[cssKeys?.sm]\r\n\r\n },\r\n [`.${classesName?.card_content}`]:{\r\n position: \"relative\",\r\n top: \"0px\",\r\n width: \"auto\",\r\n margin: \"auto\",\r\n // boxShadow: \"var(--cbmis-box-shadow-1)\" ,\r\n borderRadius: \"5px\",\r\n padding: \"0.25rem\",\r\n background: \"#fff\",\r\n display: \"block\",\r\n },\r\n [`.${classesName?.card_details}`] :{\r\n position: \"relative\",\r\n background: \"#fff\",\r\n padding: \"0.5rem\",\r\n display:\"block\",\r\n zIndex:1,\r\n }\r\n },\r\n [classesName?.card_have_back]:{\r\n \"&hover\":{\r\n [`.${classesName?.card}`]:{\r\n cursor: \"pointer\",\r\n },\r\n [`.${classesName?.card_front}`]:{\r\n transform: \"rotateY(180deg)\",\r\n },\r\n [`.${classesName?.card_back}`]:{\r\n transform: \"rotateY(0deg)\",\r\n }\r\n }\r\n },\r\n [classesName?.card_image]:{\r\n width: \"100%\",\r\n height: \"175px\",\r\n maxHeight: \"calc(45.1977vw)\",\r\n display: \"block;\",\r\n transformStyle: \"preserve-3d\",\r\n border: \"0px\",\r\n backgroundPosition: \"center\",\r\n backgroundRepeat: \"no-repeat\",\r\n backgroundSize: \"100% 100%\",\r\n position: \"relative\",\r\n color: \"#fff\",\r\n padding: \"0PX\",\r\n zIndex:1,\r\n },\r\n [classesName?.card_frame]:{\r\n opacity: \"0\",\r\n width: \"0%\",\r\n height: \"0%\",\r\n display: \"block\",\r\n position: \"absolute\",\r\n top: \"0px\",\r\n left: \"0px\",\r\n zIndex: \"var( --cbmis-z-index-10)\",\r\n transition: \"height .12s\",\r\n },\r\n [classesName?.card_image_hover]:{\r\n \"&hover\":{\r\n [`.${classesName?.card_frame}`]:{\r\n opacity: 1,\r\n height: \"100%\",\r\n width: \"100%\",\r\n }\r\n }\r\n },\r\n [classesName?.card_frame_bg]: {\r\n width: \"100%\",\r\n height: \"100%\",\r\n display: \"block\",\r\n position: \"absolute\",\r\n left: \"50%\",\r\n top: \"50%\",\r\n transform: \"translate(-50%,-50%)\",\r\n background: \"#000\",\r\n backdropFilter: \"blur(50px)\",\r\n opacity: \".88\",\r\n zIndex: \"0\",\r\n },\r\n [classesName?.card_frame_content]:{\r\n width: \"100%\",\r\n height: \"100%\",\r\n display: \"block\",\r\n position: \"absolute\",\r\n left: \"50%\",\r\n top: \"50%\",\r\n transform: \"translate(-50%,-50%)\",\r\n opacity: \"1\",\r\n zIndex: \"var( --cbmis-z-index-1)\",\r\n },\r\n },\r\n });\r\n\r\n const styleCardSx = StyleBuilder({\r\n blnRandomPrefix: true,\r\n blnIsDefaultStyle: false,\r\n blnCbmisStyle: true,\r\n objStyles:{\r\n [classesName?.sx]: (props) => {\r\n return props?.sx;\r\n },\r\n },\r\n });\r\n\r\n const styleCardFrontSx = StyleBuilder({\r\n blnRandomPrefix: true,\r\n blnIsDefaultStyle: false,\r\n blnCbmisStyle: true,\r\n objStyles:{\r\n [classesName?.sx]: (props) => {\r\n return props?.sx;\r\n },\r\n },\r\n });\r\n\r\n const styleCardBackSx = StyleBuilder({\r\n blnRandomPrefix: true,\r\n blnIsDefaultStyle: false,\r\n blnCbmisStyle: true,\r\n objStyles:{\r\n [classesName?.sx]: (props) => {\r\n return props?.sx;\r\n },\r\n },\r\n });\r\n\r\n const styleCardImageSx = StyleBuilder({\r\n blnRandomPrefix: true,\r\n blnIsDefaultStyle: false,\r\n blnCbmisStyle: true,\r\n objStyles:{\r\n [classesName?.sx]: (props) => {\r\n return props?.sx;\r\n },\r\n },\r\n });\r\n\r\n const styleCardDetailsSx = StyleBuilder({\r\n blnRandomPrefix: true,\r\n blnIsDefaultStyle: false,\r\n blnCbmisStyle: true,\r\n objStyles:{\r\n [classesName?.sx]: (props) => {\r\n return props?.sx;\r\n },\r\n },\r\n });\r\n\r\n\r\n return{\r\n classesName,\r\n style,\r\n styleCardSx,\r\n styleCardFrontSx,\r\n styleCardBackSx,\r\n styleCardImageSx,\r\n styleCardDetailsSx\r\n }\r\n}","import React, { forwardRef, useContext, useId } from \"react\";\r\nimport { ContextThemeProvider, styleFunction } from \"@cbmisorg/styles\";\r\nimport CardStyle from \"./CardStyle\";\r\nimport ErrorBoundary from \"../../_helper/errorHandeling/ErrorBoundary/ErrorBoundary\";\r\n\r\nconst Card = forwardRef((/**@type {any}*/props, ref) => {\r\n const { sx,id, hidden, disabled, dir, className, ...rest } = props;\r\n const theTheme = useContext(ContextThemeProvider);\r\n const {classesName, style, styleCardSx} = CardStyle(theTheme);\r\n const classes = style();\r\n const classesSx = styleCardSx({sx});\r\n const itemClasses = styleFunction.getClassName(classes?.[classesName?.card], classesSx?.[classesName?.sx], styleFunction.CheckDirectionItem(dir),styleFunction.CheckDisabledItem(disabled), styleFunction.CheckHiddenItem(hidden),styleFunction.checkExistsMargin(rest),styleFunction.checkExistsPadding(rest), className);\r\n const comID = id || String(useId()).slice(1,-1)\r\n\r\n return (\r\n \r\n
\r\n {props.children} \r\n
\r\n
\r\n );\r\n});\r\n\r\nexport default Card;\r\n","import React, { forwardRef, useContext, useId } from \"react\";\r\nimport { ContextThemeProvider, styleFunction } from \"@cbmisorg/styles\";\r\nimport CardStyle from \"./CardStyle\";\r\nimport ErrorBoundary from \"../../_helper/errorHandeling/ErrorBoundary/ErrorBoundary\";\r\n\r\nconst CardFront = forwardRef((/**@type {any}*/props, ref) => {\r\n const { sx, id, hidden, disabled, dir, className, ...rest } = props;\r\n const theTheme = useContext(ContextThemeProvider);\r\n const {\r\n classesName,\r\n // style,\r\n styleCardFrontSx} = CardStyle(theTheme);\r\n // const classes = style();\r\n const classesSx = styleCardFrontSx({sx});\r\n const itemClasses = styleFunction.getClassName(classesName?.card_front, classesSx?.[classesName?.sx], styleFunction.CheckDirectionItem(dir),styleFunction.CheckDisabledItem(disabled), styleFunction.CheckHiddenItem(hidden),styleFunction.checkExistsMargin(rest),styleFunction.checkExistsPadding(rest), className);\r\n\r\n const comID = id || String(useId()).slice(1,-1)\r\n\r\n return (\r\n \r\n
\r\n {props.children} \r\n
\r\n
\r\n );\r\n});\r\n\r\nexport default CardFront;\r\n","import React, { forwardRef, useContext, useId } from \"react\";\r\nimport { ContextThemeProvider, styleFunction } from \"@cbmisorg/styles\";\r\nimport CardStyle from \"./CardStyle\";\r\nimport ErrorBoundary from \"../../_helper/errorHandeling/ErrorBoundary/ErrorBoundary\";\r\n\r\nconst CardBack = forwardRef((/**@type {any}*/props, ref) => {\r\n const { sx,id, hidden, disabled, dir, className, ...rest } = props;\r\n const theTheme = useContext(ContextThemeProvider);\r\n const {\r\n classesName,\r\n // style,\r\n styleCardBackSx} = CardStyle(theTheme);\r\n // const classes = style();\r\n const classesSx = styleCardBackSx({sx});\r\n const itemClasses = styleFunction.getClassName(classesName?.card_back, classesSx?.[classesName?.sx], styleFunction.CheckDirectionItem(dir),styleFunction.CheckDisabledItem(disabled), styleFunction.CheckHiddenItem(hidden),styleFunction.checkExistsMargin(rest),styleFunction.checkExistsPadding(rest), className);\r\n\r\n const comID = id || String(useId()).slice(1,-1)\r\n\r\n return (\r\n \r\n
\r\n {props.children} \r\n
\r\n
\r\n );\r\n});\r\n\r\nexport default CardBack;\r\n","import React, { forwardRef, useContext, useId } from \"react\";\r\nimport { ContextThemeProvider, styleFunction } from \"@cbmisorg/styles\";\r\nimport CardStyle from \"./CardStyle\";\r\n\r\nconst CardImage = forwardRef((/**@type {any}*/props, ref) => {\r\n const { src, title, hoverContent, sx, id, hidden, disabled, dir, className, ...rest } = props;\r\n const theTheme = useContext(ContextThemeProvider);\r\n const {classesName,style, styleCardImageSx} = CardStyle(theTheme);\r\n const classes = style();\r\n const classesSx = styleCardImageSx({sx});\r\n const itemClasses = styleFunction.getClassName(classesName?.card_image, hoverContent ? classes?.[classesName?.card_image_hover] : \"\", classesSx?.[classesName?.sx], styleFunction.CheckDirectionItem(dir),styleFunction.CheckDisabledItem(disabled), styleFunction.CheckHiddenItem(hidden),styleFunction.checkExistsMargin(rest),styleFunction.checkExistsPadding(rest), className);\r\n\r\n const comID = id || String(useId()).slice(1,-1)\r\n\r\n return (\r\n \r\n
{props.children}
\r\n
\r\n
\r\n
{hoverContent}
\r\n
\r\n
\r\n );\r\n});\r\n\r\nexport default CardImage;\r\n","import React, { forwardRef, useContext, useId } from \"react\";\r\nimport { ContextThemeProvider, styleFunction } from \"@cbmisorg/styles\";\r\nimport CardStyle from \"./CardStyle\";\r\nimport ErrorBoundary from \"../../_helper/errorHandeling/ErrorBoundary/ErrorBoundary\";\r\n\r\nconst CardDetails = forwardRef((/**@type {any}*/props, ref) => {\r\n const { sx, id, hidden, disabled, dir, className, ...rest } = props;\r\n const theTheme = useContext(ContextThemeProvider);\r\n const {\r\n classesName,\r\n // style, \r\n styleCardDetailsSx} = CardStyle(theTheme);\r\n // const classes = style();\r\n const classesSx = styleCardDetailsSx({sx});\r\n const itemClasses = styleFunction.getClassName(classesName?.card_details, classesSx?.[classesName?.sx], styleFunction.CheckDirectionItem(dir),styleFunction.CheckDisabledItem(disabled), styleFunction.CheckHiddenItem(hidden),styleFunction.checkExistsMargin(rest),styleFunction.checkExistsPadding(rest), className);\r\n\r\n const comID = id || String(useId()).slice(1,-1)\r\n\r\n return (\r\n \r\n {props.children} \r\n
\r\n );\r\n});\r\n\r\nexport default CardDetails;\r\n","/* eslint-disable no-fallthrough */\r\nimport React, { forwardRef, useContext } from \"react\";\r\nimport { ContextThemeProvider, styleFunction } from \"@cbmisorg/styles\";\r\nimport LoaderStyle from \"./LoaderStyle\";\r\nimport Container from \"../../layout/Container/Container\";\r\n\r\nconst Loader = forwardRef((/**@type {any}*/ props, ref) => {\r\n const theTheme = useContext(ContextThemeProvider);\r\n const { classesName, style, styleSx } = LoaderStyle(theTheme);\r\n const { mode, color, backdrop, sx, hidden, disabled, dir, className, id, ...rest } = props;\r\n const classes = style();\r\n const classesSx = styleSx({ sx, color, backdrop });\r\n const itemClasses = styleFunction.getClassName(\r\n classes?.[classesName?.loader_container],\r\n classesSx?.[classesName?.sx],\r\n styleFunction.CheckDirectionItem(dir),\r\n styleFunction.CheckDisabledItem(disabled),\r\n styleFunction.CheckHiddenItem(hidden),\r\n styleFunction.checkExistsMargin(rest),\r\n styleFunction.checkExistsPadding(rest),\r\n className\r\n );\r\n\r\n return backdrop ? (\r\n \r\n \r\n \r\n ) : null;\r\n});\r\n\r\nexport default Loader;\r\n","import { StyleBuilder, styleVariables, cssKeys, mainTheme, styleFunction } from \"@cbmisorg/styles\";\r\n\r\nexport default (objThemeInfo) => {\r\n const cssObject = objThemeInfo?.cssObject || mainTheme?.cssObject;\r\n\r\n const classesName = {\r\n loader_container: `${styleVariables?.prefixDefaultClassName}_loader_container`,\r\n loader: `${styleVariables?.prefixDefaultClassName}_loader`,\r\n sx: `${styleVariables?.prefixDefaultClassName}_loader_sx`,\r\n };\r\n\r\n const style = StyleBuilder({\r\n blnRandomPrefix: false,\r\n blnIsDefaultStyle: true,\r\n blnCbmisStyle: true,\r\n objStyles: {\r\n [classesName?.loader_container]: {\r\n height: \"100vh\",\r\n width: \"100vw\",\r\n maxHeight: \"100vh\",\r\n display: \"flex\",\r\n justifyContent: \"center\",\r\n alignItems: \"center\",\r\n alignContent: \"center\",\r\n margin: \"auto\",\r\n position: \"fixed\",\r\n top: 0,\r\n left: 0,\r\n overflow: \"auto\",\r\n zIndex: 10000,\r\n background: \"#00000050\",\r\n },\r\n [classesName?.loader]: {\r\n display: \"inline-block\",\r\n width: cssObject?.size?.[cssKeys?.item_sm],\r\n height: cssObject?.size?.[cssKeys?.item_sm],\r\n verticalAlign: \"middle\",\r\n pointerEvents: \"none\",\r\n margin: \"auto\",\r\n zIndex: 1,\r\n\r\n border: \"0.25rem dotted currentcolor\",\r\n borderBottomColor: \"transparent\",\r\n borderRadius: \"50%\",\r\n animation: \"1s loader-01 linear infinite\",\r\n\r\n \"@keyframes loader-01\": {\r\n from: {\r\n WebkitTransform: \"rotate(0deg)\",\r\n transform: \"rotate(0deg)\",\r\n },\r\n to: {\r\n WebkitTransform: \"rotate(360deg)\",\r\n transform: \"rotate(360deg)\",\r\n },\r\n },\r\n },\r\n },\r\n });\r\n\r\n const styleSx = StyleBuilder({\r\n blnRandomPrefix: true,\r\n blnIsDefaultStyle: false,\r\n blnCbmisStyle: true,\r\n objStyles: {\r\n [classesName?.loader]: (props) => {\r\n return {\r\n color: styleFunction?.checkColorReturnValue(props.color || cssObject?.color?.[cssKeys?.primary]),\r\n };\r\n },\r\n [classesName?.sx]: (props) => {\r\n return {\r\n ...props?.sx,\r\n };\r\n },\r\n },\r\n });\r\n\r\n return {\r\n classesName,\r\n style,\r\n styleSx,\r\n };\r\n};\r\n","/* eslint-disable no-fallthrough */\r\nimport React, { forwardRef, useContext } from \"react\";\r\nimport { ContextThemeProvider, styleFunction } from \"@cbmisorg/styles\";\r\nimport PaperStyle from \"./PaperStyle\";\r\nimport ErrorBoundary from \"../../_helper/errorHandeling/ErrorBoundary/ErrorBoundary\";\r\n\r\nconst Paper = forwardRef((/**@type {any}*/props, ref) => {\r\n const theTheme = useContext(ContextThemeProvider);\r\n const {classesName, style, styleSx} = PaperStyle(theTheme);\r\n const { elevation, width, outline, sx, hidden, disabled, dir, className, id, ...rest } = props;\r\n const classes = style();\r\n const classesSx = styleSx({sx,elevation, width, outline});\r\n const itemClasses = styleFunction.getClassName(classes?.[classesName?.paper], classesSx?.[classesName?.sx], styleFunction.CheckDirectionItem(dir),styleFunction.CheckDisabledItem(disabled), styleFunction.CheckHiddenItem(hidden),styleFunction.checkExistsMargin(rest),styleFunction.checkExistsPadding(rest), className);\r\n\r\n\r\n return (\r\n \r\n {props?.children} \r\n
\r\n );\r\n});\r\n\r\nexport default Paper;\r\n","import {\r\n StyleBuilder,\r\n styleVariables,\r\n cssKeys,\r\n mainTheme,\r\n styleFunction,\r\n} from \"@cbmisorg/styles\";\r\n\r\n\r\nexport default(objThemeInfo)=>{\r\n const cssObject = objThemeInfo?.cssObject || mainTheme?.cssObject;\r\n\r\n const classesName = {\r\n paper: `${styleVariables?.prefixDefaultClassName}_paper`,\r\n sx: `${styleVariables?.prefixDefaultClassName}_paper_sx`,\r\n };\r\n\r\n const style = StyleBuilder({\r\n blnRandomPrefix: false,\r\n blnIsDefaultStyle: true,\r\n blnCbmisStyle: true,\r\n objStyles: {\r\n [classesName?.paper]: {\r\n display: \"block\",\r\n margin: \"auto\",\r\n position: \"relative\",\r\n overflow: \"auto\",\r\n boxSizing: cssObject?.boxSizing?.[cssKeys?.borderBox],\r\n\r\n }\r\n },\r\n });\r\n\r\n const styleSx = StyleBuilder({\r\n blnRandomPrefix: true,\r\n blnIsDefaultStyle: false,\r\n blnCbmisStyle: true,\r\n objStyles: {\r\n [classesName?.sx]: (props) => {\r\n const {elevation=null, width=null, outline=null, sx={sm:null}} = props\r\n return {\r\n fontSize:cssObject?.text?.size?.body1,\r\n color: cssObject?.color?.bodyColor,\r\n padding: cssObject?.spacing?.[cssKeys?.md],\r\n borderRadius: cssObject?.border?.[cssKeys?.rounded]?.sm,\r\n ...getBorder(props),\r\n ...getWidth(props),\r\n ...getShadow(props),\r\n ...props?.sx,\r\n sm:{\r\n padding: cssObject?.spacing?.[cssKeys?.sm],\r\n ...props?.sx?.sm,\r\n },\r\n };\r\n },\r\n },\r\n });\r\n\r\n const getWidth = (props) => {\r\n switch (String(props?.width).toLowerCase()) {\r\n case \"xl\":\r\n return {\r\n width: cssObject?.size?.[cssKeys?.xl]\r\n }\r\n case \"lg\":\r\n return {\r\n width: cssObject?.size?.[cssKeys?.lg]\r\n }\r\n case \"md\":\r\n return {\r\n width: cssObject?.size?.[cssKeys?.md]\r\n }\r\n case \"sm\":\r\n return {\r\n width: cssObject?.size?.[cssKeys?.sm]\r\n }\r\n case \"sm\":\r\n return {\r\n width: cssObject?.size?.[cssKeys?.xs]\r\n }\r\n case \"fluid\":\r\n return {\r\n width: cssObject?.size?.[cssKeys?.full]\r\n }\r\n case \"half\":\r\n return {\r\n width: cssObject?.size?.[cssKeys?.half]\r\n }\r\n default:\r\n return {\r\n width: cssObject?.size?.[cssKeys?.full]\r\n }\r\n }\r\n };\r\n const getBorder = (props) => {\r\n switch (parseInt(props?.outline)) {\r\n case 0:\r\n return {\r\n color: styleFunction.checkColorReturnValue(cssObject?.color?.bodyColor),\r\n border: \"none\",\r\n };\r\n case 1:\r\n return {\r\n color: styleFunction.checkColorReturnValue(cssObject?.color?.bodyColor),\r\n border: `${cssObject?.size?.[cssKeys?.border_xs]} ${cssObject?.border?.[cssKeys?.border]?.solid} ${styleFunction.checkColorReturnValue(cssObject?.color?.bodyColor)}`,\r\n };\r\n case 2:\r\n return {\r\n border: `${cssObject?.size?.[cssKeys?.border_sm]} ${cssObject?.border?.[cssKeys?.border]?.solid} ${styleFunction.checkColorReturnValue(cssObject?.color?.bodyColor)}`,\r\n };\r\n case 3:\r\n return {\r\n border: `${cssObject?.size?.[cssKeys?.border_md]} ${cssObject?.border?.[cssKeys?.border]?.solid} ${styleFunction.checkColorReturnValue(cssObject?.color?.bodyColor)}`,\r\n };\r\n case 4:\r\n return {\r\n border: `${cssObject?.size?.[cssKeys?.border_lg]} ${cssObject?.border?.[cssKeys?.border]?.solid} ${styleFunction.checkColorReturnValue(cssObject?.color?.bodyColor)}`,\r\n };\r\n case 5:\r\n return {\r\n border: `${cssObject?.size?.[cssKeys?.border_xl]} ${cssObject?.border?.[cssKeys?.border]?.solid} ${styleFunction.checkColorReturnValue(cssObject?.color?.bodyColor)}`,\r\n };\r\n default:\r\n return {\r\n width: cssObject?.border?.size?.[cssKeys?.none]\r\n };\r\n }\r\n };\r\n\r\n const getShadow = (props) => {\r\n switch (parseInt(props?.elevation)) {\r\n case 0:\r\n return {\r\n boxShadow: \"none\",\r\n };\r\n case 1:\r\n return {\r\n boxShadow: cssObject?.boxShadow?.[cssKeys?.xs],\r\n };\r\n case 2:\r\n return {\r\n boxShadow: cssObject?.boxShadow?.[cssKeys?.sm],\r\n };\r\n case 3:\r\n return {\r\n boxShadow: cssObject?.boxShadow?.[cssKeys?.md],\r\n };\r\n case 4:\r\n return {\r\n boxShadow: cssObject?.boxShadow?.[cssKeys?.lg],\r\n };\r\n case 5:\r\n return {\r\n boxShadow: cssObject?.boxShadow?.[cssKeys?.xl],\r\n };\r\n default:\r\n return {\r\n boxShadow: cssObject?.boxShadow?.[cssKeys?.sm],\r\n };\r\n }\r\n };\r\n\r\n return{\r\n classesName,\r\n style,\r\n styleSx,\r\n }\r\n}","\n import API from \"!../../../../../node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js\";\n import domAPI from \"!../../../../../node_modules/style-loader/dist/runtime/styleDomAPI.js\";\n import insertFn from \"!../../../../../node_modules/style-loader/dist/runtime/insertBySelector.js\";\n import setAttributes from \"!../../../../../node_modules/style-loader/dist/runtime/setAttributesWithoutAttributes.js\";\n import insertStyleElement from \"!../../../../../node_modules/style-loader/dist/runtime/insertStyleElement.js\";\n import styleTagTransformFn from \"!../../../../../node_modules/style-loader/dist/runtime/styleTagTransform.js\";\n import content, * as namedExport from \"!!../../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[1].use[1]!./AnimationBox.css\";\n \n \n\nvar options = {};\n\noptions.styleTagTransform = styleTagTransformFn;\noptions.setAttributes = setAttributes;\noptions.insert = insertFn.bind(null, \"head\");\noptions.domAPI = domAPI;\noptions.insertStyleElement = insertStyleElement;\n\nvar update = API(content, options);\n\n\n\nexport * from \"!!../../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[1].use[1]!./AnimationBox.css\";\n export default content && content.locals ? content.locals : undefined;\n","import React, { useState, useEffect, useRef } from \"react\";\r\nimport \"./AnimationBox.css\";\r\n/**\r\n * AnimationBox Component.\r\n *\r\n * @param {{\r\n * type: 'fadeIn' | 'fadeOut' | 'fadeInGrow' | 'fadeOutGrow' | 'slideIn' | 'slideOut' | 'grow' |\r\n * 'slideInRotate' | 'slideOutRotate' | 'fadeOutSlideOut' | 'wobble' | 'hinge' | 'flip' | 'flipInX' |\r\n * 'flipOutX' | 'flipInY' | 'flipOutY' | 'rollIn' | 'rollOut' | 'rotateIn' | 'rotateOut' | 'slideInUp' |\r\n * 'slideInDown' | 'slideInLeft' | 'slideInRight' | 'slideOutUp' | 'slideOutDown' | 'slideOutLeft' | 'slideOutRight',\r\n * easing: 'linear' | 'ease-in' | 'ease-out' | 'ease-in-out' | [other CSS timing functions],\r\n * trigger: 'auto' | 'manual',\r\n * forceTrigger: boolean,\r\n * animationMode: 'forward' | 'loop' | 'reverse'\r\n * }} props The properties.\r\n */\r\n\r\n\r\n\r\nconst AnimationBox = ({\r\n children,\r\n type,\r\n duration = \"1s\",\r\n delay = \"1s\",\r\n easing = \"linear\",\r\n trigger = \"auto\",\r\n forceTrigger = false,\r\n animationMode = \"forward\",\r\n}) => {\r\n const [active, setActive] = useState(false);\r\n const [shouldRender, setShouldRender] = useState(true);\r\n const animationRef = useRef(null);\r\n\r\n useEffect(() => {\r\n if (trigger === \"manual\" && forceTrigger) {\r\n setActive(true);\r\n }\r\n }, [forceTrigger, trigger]);\r\n\r\n const computedClass = active ?`animation-${type}`: \"\";\r\n\r\n let initialStyles = {};\r\n if (\r\n type.includes(\"fadeIn\") ||\r\n type.includes(\"flash\") ||\r\n type === \"rotateIn\"\r\n ) {\r\n initialStyles.opacity = 0;\r\n }\r\n if (\r\n type.includes(\"slideIn\") ||\r\n type.includes(\"swing\") ||\r\n type.includes(\"jello\") ||\r\n type.includes(\"flipIn\") ||\r\n type.includes(\"rollIn\")\r\n ) {\r\n initialStyles.transform = \"translateX(-100%)\";\r\n }\r\n if (type.includes(\"grow\") || type.includes(\"rubberBand\")) {\r\n initialStyles.transform = \"scale(0)\";\r\n }\r\n if (type.includes(\"bounce\") || type.includes(\"pulse\")) {\r\n initialStyles = {};\r\n }\r\n\r\n let animationDirection = \"normal\";\r\n let animationIterationCount = \"1\";\r\n\r\n if (animationMode === \"loop\") {\r\n animationIterationCount = \"infinite\";\r\n } else if (animationMode === \"reverse\") {\r\n animationDirection = \"alternate\";\r\n animationIterationCount = \"infinite\";\r\n }\r\n\r\n useEffect(() => {\r\n const node = animationRef.current;\r\n if (node) {\r\n node.addEventListener(\"animationend\", handleAnimationEnd);\r\n return () => {\r\n node.removeEventListener(\"animationend\", handleAnimationEnd);\r\n };\r\n }\r\n }, [type, animationMode]);\r\n\r\n const handleAnimationEnd = (e) => {\r\n if (\r\n (type.includes(\"slideOut\") ||\r\n type.includes(\"SlideOut\") ||\r\n type.includes(\"fadeOut\") ||\r\n type.includes(\"flash\") ||\r\n type.includes(\"swing\") ||\r\n type.includes(\"rubberBand\") ||\r\n type.includes(\"hinge\") ||\r\n type.includes(\"flipOut\") ||\r\n type.includes(\"rollOut\") ||\r\n type.includes(\"rotateOut\")) &&\r\n animationMode === \"forward\"\r\n ) {\r\n setShouldRender(false);\r\n }\r\n };\r\n\r\n useEffect(() => {\r\n const handleIntersection = (entries) => {\r\n entries.forEach((entry) => {\r\n if (trigger === \"auto\") {\r\n if (entry.isIntersecting) {\r\n setActive(true);\r\n } else {\r\n setActive(false);\r\n }\r\n } else if (\r\n trigger === \"manual\" &&\r\n forceTrigger &&\r\n entry.isIntersecting\r\n ) {\r\n setActive(true);\r\n }\r\n });\r\n };\r\n\r\n const observer = new IntersectionObserver(handleIntersection, {\r\n threshold: [0, 1],\r\n });\r\n\r\n if (animationRef.current) {\r\n observer.observe(animationRef.current);\r\n }\r\n\r\n return () => {\r\n if (animationRef.current) {\r\n observer.unobserve(animationRef.current);\r\n }\r\n };\r\n }, [animationRef, trigger, forceTrigger]);\r\n\r\n return (\r\n \r\n {type === \"none\" ? (\r\n {children} \r\n ) : (\r\n shouldRender && (\r\n \r\n
\r\n {children}\r\n
\r\n
\r\n )\r\n )}\r\n \r\n );\r\n};\r\n\r\nexport default React.memo(AnimationBox);\r\n","\"use client\";\r\nfunction getPkgConfigMaterial() {\r\n const initConfig = {\r\n blnIsTestingMode: false,\r\n };\r\n return initConfig;\r\n}\r\n\r\nexport var pkgConfigMaterial = getPkgConfigMaterial();\r\n\r\nexport function setPkgConfigMaterial({ blnIsTestingMode = true }) {\r\n pkgConfigMaterial.blnIsTestingMode = blnIsTestingMode;\r\n}\r\n\r\n//#region cbmis dataDisplay\r\nexport { default as Avatar } from \"./dataDisplay/Avatar/Avatar\";\r\nexport { default as Badge } from \"./dataDisplay/Badge/Badge\";\r\nexport { default as Chip } from \"./dataDisplay/Chip/Chip\";\r\nexport { default as Counter } from \"./dataDisplay/Counter/Counter\";\r\nexport { default as Modal } from \"./dataDisplay/Modal/Modal\";\r\nexport { default as ModalHeader } from \"./dataDisplay/Modal/ModalHeader\";\r\nexport { default as ModalBody } from \"./dataDisplay/Modal/ModalBody\";\r\nexport { default as ModalFooter } from \"./dataDisplay/Modal/ModalFooter\";\r\n// export { default as Tooltip } from \"./dataDisplay/Tooltip/Tooltip\";\r\nexport { default as Typography } from \"./dataDisplay/Typography/Typography\";\r\nexport { default as Table } from \"./dataDisplay/Table/Table\";\r\nexport { default as TableHead } from \"./dataDisplay/Table/TableHead\";\r\nexport { default as TableBody } from \"./dataDisplay/Table/TableBody\";\r\nexport { default as TableFooter } from \"./dataDisplay/Table/TableFooter\";\r\nexport { default as TableRow } from \"./dataDisplay/Table/TableRow\";\r\nexport { default as TableCell } from \"./dataDisplay/Table/TableCell\";\r\n// export { default as VideoPlayer } from \"./dataDisplay/videoPlayer/VideoPlayer\";\r\n//#endregion\r\n\r\n//#region cbmis feedback\r\nexport * as Alert from \"./feedback/Alert/Alert\";\r\nexport * as Confirmation from \"./feedback/Confirmation/Confirmation\";\r\nexport { default as InlineTextDialog } from \"./feedback/inlineTextDialog/InlineTextDialog\";\r\n\r\nexport { default as Note } from \"./feedback/Note/Note\";\r\n//#endregion\r\n\r\n//#region cbmisInput\r\nexport { default as Button } from \"./inputs/Button/Button\";\r\nexport { default as CheckboxGroup } from \"./inputs/CheckboxGroup/CheckboxGroup\";\r\nexport { default as DatePicker } from \"./inputs/DatePicker/DatePicker\";\r\nexport { default as ErrorMessage } from \"./inputs/ErrorMessage/ErrorMessage\";\r\nexport { default as List } from \"./inputs/List/List\";\r\nexport { default as MultipleList } from \"./inputs/MultipleList/MultipleList\";\r\nexport { default as RadioButtons } from \"./inputs/RadioButtons/RadioButtons\";\r\nexport { default as Text } from \"./inputs/Text/Text\";\r\nexport { default as TextArea } from \"./inputs/TextArea/TextArea\";\r\nexport { default as Password } from \"./inputs/Password/Password\";\r\nexport { default as Number } from \"./inputs/Number/Number\";\r\nexport { default as Rating } from \"./inputs/Rating/Rating\";\r\nexport { default as RangeSlider } from \"./inputs/RangeSlider/RangeSlider\";\r\nexport { default as Switch } from \"./inputs/Switch/Switch\";\r\n// export { default as Color } from \"./inputs/Color/Color\";\r\nexport { default as Option } from \"./inputs/option/Option\";\r\nexport { default as GroupField } from \"./inputs/GroupField/GroupField\";\r\nexport { default as RadialProgressBar } from \"./inputs/RadialProgressBar/RadialProgressBar\";\r\n\r\n//#endregion\r\n\r\n//#region cbmis layout\r\nexport { default as Box } from \"./layout/Box/Box\";\r\nexport { default as Container } from \"./layout/Container/Container\";\r\nexport { default as Line } from \"./layout/Line/Line\";\r\nexport { default as Grid } from \"./layout/Grid/Grid\";\r\n\r\n//cbmis navigation\r\n// export { default as BottomBar } from \"./navigation/BottomBar/BottomBar\";\r\nexport { default as Breadcrumbs } from \"./navigation/Breadcrumbs/Breadcrumbs\";\r\nexport { default as Drawer } from \"./navigation/Drawer/Drawer\";\r\nexport { default as Menu } from \"./navigation/Menu/Menu\";\r\nexport { default as MenuItem } from \"./navigation/Menu/MenuItem\";\r\n// export { default as Pagination } from \"./navigation/Pagination/Pagination\";\r\n// export { default as SpeedDial } from \"./navigation/SpeedDial/SpeedDial\";\r\n// export { default as SpeedDialAction } from \"./navigation/SpeedDial/SpeedDialAction\";\r\nexport { default as Stepper } from \"./navigation/Stepper/Stepper\";\r\nexport { default as Slideshow } from \"./surfaces/Slideshow/Slideshow\";\r\nexport { default as Slide } from \"./surfaces/Slideshow/Slide\";\r\nexport { default as Tabs } from \"./navigation/Tabs/Tabs\";\r\n// export { default as ParallaxScrolling } from \"./navigation/ParallaxScrolling/ParallaxScrolling\";\r\nexport { default as AppBar } from \"./navigation/AppBar/AppBar\";\r\nexport { default as GroupBar } from \"./navigation/groupBar/GroupBar\";\r\nexport { default as Nav } from \"./navigation/nav/Nav\";\r\n// export { default as BtnGoToTop } from \"./navigation/btnGoToTop/BtnGoToTop\";\r\n//#endregion\r\n\r\n//#region cbmis surfaces\r\nexport { default as Accordion } from \"./surfaces/Accordion/Accordion\";\r\nexport { default as AccordionTab } from \"./surfaces/Accordion/AccordionTab\";\r\nexport { default as AccordionSummary } from \"./surfaces/Accordion/AccordionSummary\";\r\nexport { default as AccordionDetails } from \"./surfaces/Accordion/AccordionDetails\";\r\nexport { default as Card } from \"./surfaces/Card/Card\";\r\nexport { default as CardFront } from \"./surfaces/Card/CardFront\";\r\nexport { default as CardBack } from \"./surfaces/Card/CardBack\";\r\nexport { default as CardImage } from \"./surfaces/Card/CardImage\";\r\nexport { default as CardDetails } from \"./surfaces/Card/CardDetails\";\r\n// export { default as Glass } from \"./surfaces/Glass/Glass\";\r\nexport { default as Loader } from \"./surfaces/Loader/Loader\";\r\nexport { default as Paper } from \"./surfaces/Paper/Paper\";\r\nexport { default as AnimationBox } from \"./surfaces/AnimationBox/AnimationBox\";\r\n\r\n//#endregion\r\n","// Imports\nimport ___CSS_LOADER_API_SOURCEMAP_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/sourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/api.js\";\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_SOURCEMAP_IMPORT___);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, \":root {\\r\\n --data-cbmis: \\\"default-css\\\";\\r\\n}\\r\\n\", \"\",{\"version\":3,\"sources\":[\"webpack://./style/src/style/dataCbmisDefault.css\"],\"names\":[],\"mappings\":\"AAAA;IACI,2BAA2B;AAC/B\",\"sourcesContent\":[\":root {\\r\\n --data-cbmis: \\\"default-css\\\";\\r\\n}\\r\\n\"],\"sourceRoot\":\"\"}]);\n// Exports\nexport default ___CSS_LOADER_EXPORT___;\n","// Imports\nimport ___CSS_LOADER_API_SOURCEMAP_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/sourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/api.js\";\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_SOURCEMAP_IMPORT___);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, \":root {\\r\\n --data-cbmis: \\\"sx-css\\\";\\r\\n}\", \"\",{\"version\":3,\"sources\":[\"webpack://./style/src/style/dataCbmisSx.css\"],\"names\":[],\"mappings\":\"AAAA;IACI,sBAAsB;AAC1B\",\"sourcesContent\":[\":root {\\r\\n --data-cbmis: \\\"sx-css\\\";\\r\\n}\"],\"sourceRoot\":\"\"}]);\n// Exports\nexport default ___CSS_LOADER_EXPORT___;\n","// Imports\nimport ___CSS_LOADER_API_SOURCEMAP_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/sourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/api.js\";\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_SOURCEMAP_IMPORT___);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, \":root {\\r\\n --data-cbmis: \\\"client-css\\\";\\r\\n}\", \"\",{\"version\":3,\"sources\":[\"webpack://./style/src/style/dataClientStyle.css\"],\"names\":[],\"mappings\":\"AAAA;IACI,0BAA0B;AAC9B\",\"sourcesContent\":[\":root {\\r\\n --data-cbmis: \\\"client-css\\\";\\r\\n}\"],\"sourceRoot\":\"\"}]);\n// Exports\nexport default ___CSS_LOADER_EXPORT___;\n","// Imports\nimport ___CSS_LOADER_API_SOURCEMAP_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/sourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/api.js\";\nimport ___CSS_LOADER_AT_RULE_IMPORT_0___ from \"-!../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[1].use[1]!./var.css\";\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_SOURCEMAP_IMPORT___);\n___CSS_LOADER_EXPORT___.i(___CSS_LOADER_AT_RULE_IMPORT_0___);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, \"/* @import-normalize; */\\r\\n\\r\\n*{\\r\\n font-family: \\\"Poppins\\\", roboto;\\r\\n font-family: 'Satisfy', cursive;\\r\\n font-family: 'Cairo Play', cursive;\\r\\n font-family: 'Changa', sans-serif;\\r\\n font-family: 'Almarai', 'Cairo', sans-serif;\\r\\n /* font-family: 'Mada', sans-serif; */\\r\\n font-family: 'Cairo', sans-serif;\\r\\n\\r\\n\\r\\n margin: var(--cbmis-spacer-0) auto;\\r\\n padding: var(--cbmis-spacer-0);\\r\\n }\\r\\n\\r\\nbody{\\r\\n /* margin: var(--cbmis-spacer-0);\\r\\n padding: var(--cbmis-spacer-0);\\r\\n height: 100vh;\\r\\n width: 100wh;\\r\\n margin: var(--cbmis-spacer-0);\\r\\n color: #111;\\r\\n font-size: var(--cbmis-body-font-size);\\r\\n line-height: var(--cbmis-body-line-height);\\r\\n letter-spacing: var(--cbmis-spacer-0);\\r\\n font-weight: var(--cbmis-body-font-weight);\\r\\n scroll-margin-top: calc(var(--MuiDocs-header-height) + 32px);\\r\\n background: var(--cbmis-white);\\r\\n */\\r\\n\\r\\n color: #374151;\\r\\n background-color: #f6f6f6;\\r\\n overflow-x:hidden\\r\\n}\\r\\n\\r\\n/* width */\\r\\n .cbmis-width-xl{\\r\\n width: var(--cbmis-width-xl) !important;\\r\\n }\\r\\n .cbmis-width-lg{\\r\\n width: var(--cbmis-width-lg) !important;\\r\\n }\\r\\n .cbmis-width-md{\\r\\n width: var(--cbmis-width-md) !important;\\r\\n }\\r\\n .cbmis-width-sm{\\r\\n width: var(--cbmis-width-sm) !important;\\r\\n }\\r\\n .cbmis-width-xs{\\r\\n width: var(--cbmis-width-xs) !important;\\r\\n }\\r\\n .cbmis-width-fluid{\\r\\n width: var(--cbmis-width-fluid) !important;\\r\\n }\\r\\n .cbmis-width-half{\\r\\n width: var(--cbmis-width-half) !important;\\r\\n }\\r\\n\\r\\n\\r\\n .cbmis-border-width-0{\\r\\n border: none;\\r\\n }\\r\\n .cbmis-border-width-1{\\r\\n border: var(--cbmis-border-width-1) solid var(--cbmis-border-color);\\r\\n }\\r\\n .cbmis-border-width-2{\\r\\n border: var(--cbmis-border-width-2) solid var(--cbmis-border-color);\\r\\n }\\r\\n .cbmis-border-width-3{\\r\\n border: var(--cbmis-border-width-3) solid var(--cbmis-border-color);\\r\\n }\\r\\n .cbmis-border-width-4{\\r\\n border: var(--cbmis-border-width-4) solid var(--cbmis-border-color);\\r\\n }\\r\\n .cbmis-border-width-5{\\r\\n border: var(--cbmis-border-width-5) solid var(--cbmis-border-color);\\r\\n }\\r\\n\\r\\n /*shape*/\\r\\n .cbmis-shape-circle{\\r\\n border-radius: var(--cbmis-border-radius-pill);\\r\\n }\\r\\n .cbmis-shape-oval{\\r\\n clip-path: var(--cbmis-clip-path-oval);\\r\\n }\\r\\n .cbmis-shape-square{\\r\\n border-radius: var(--cbmis-border-radius-md);\\r\\n }\\r\\n .cbmis-shape-rectangle{\\r\\n border-radius: var(--cbmis-border-radius-md);\\r\\n padding: 0 var(--cbmis-spacer);\\r\\n\\r\\n --cbmis-width-item-xs: calc(var(--cbmis-spacer-4) /1.2);\\r\\n --cbmis-width-item-sm: calc(var(--cbmis-spacer-5)/1.2);\\r\\n --cbmis-width-item-md: calc(4rem /1.2);\\r\\n --cbmis-width-item-lg: calc(5rem/1.2);\\r\\n --cbmis-width-item-xl: calc(6rem/1.2);\\r\\n --cbmis-width-item-fluid: calc(100%/1.2);\\r\\n --cbmis-width-item-half:calc(50% /1.2);\\r\\n }\\r\\n .cbmis-shape-pentagon{\\r\\n clip-path: var(--cbmis-clip-path-pentagon);\\r\\n }\\r\\n .cbmis-shape-hexagon{\\r\\n clip-path: var(--cbmis-clip-path-hexagon);\\r\\n }\\r\\n .cbmis-shape-heptagon{\\r\\n clip-path: var(--cbmis-clip-path-heptagon);\\r\\n }\\r\\n .cbmis-shape-octagon{\\r\\n clip-path: var(--cbmis-clip-path-octagon);\\r\\n }\\r\\n .cbmis-shape-star{\\r\\n clip-path: var(--cbmis-clip-path-star);\\r\\n }\\r\\n .cbmis-shape-top-chevron{\\r\\n clip-path: var(--cbmis-clip-path-top-chevron);\\r\\n }\\r\\n .cbmis-shape-left-chevron{\\r\\n clip-path: var(--cbmis-clip-path-left-chevron);\\r\\n }\\r\\n .cbmis-shape-bottom-chevron{\\r\\n clip-path: var(--cbmis-clip-path-bottom-chevron);\\r\\n }\\r\\n .cbmis-shape-right-chevron{\\r\\n clip-path: var(--cbmis-clip-path-right-chevron);\\r\\n }\\r\\n \\r\\n /*margin*/\\r\\n .cbmis-margin-0{\\r\\n margin: var(--cbmis-margin-0) !important;\\r\\n }\\r\\n .cbmis-margin-1{\\r\\n margin: var(--cbmis-margin-1) !important;\\r\\n }\\r\\n .cbmis-margin-2{\\r\\n margin: var(--cbmis-margin-2) !important;\\r\\n }\\r\\n .cbmis-margin-3{\\r\\n margin: var(--cbmis-margin-3) !important;\\r\\n }\\r\\n .cbmis-margin-4{\\r\\n margin: var(--cbmis-margin-4) !important;\\r\\n }\\r\\n .cbmis-margin-5{\\r\\n margin: var(--cbmis-margin-5) !important;\\r\\n }\\r\\n .cbmis-margin-6{\\r\\n margin: var(--cbmis-margin-6) !important;\\r\\n }\\r\\n .cbmis-margin-7{\\r\\n margin: var(--cbmis-margin-7) !important;\\r\\n }\\r\\n .cbmis-margin-8{\\r\\n margin: var(--cbmis-margin-8) !important;\\r\\n }\\r\\n .cbmis-margin-9{\\r\\n margin: var(--cbmis-margin-9) !important;\\r\\n }\\r\\n .cbmis-margin-10{\\r\\n margin: var(--cbmis-margin-10) !important;\\r\\n }\\r\\n .cbmis-margin-auto{\\r\\n margin: auto !important;\\r\\n }\\r\\n \\r\\n /*margin-top*/\\r\\n .cbmis-margin-top-0{\\r\\n margin-top: var(--cbmis-margin-0) !important;\\r\\n }\\r\\n .cbmis-margin-top-1{\\r\\n margin-top: var(--cbmis-margin-1) !important;\\r\\n }\\r\\n .cbmis-margin-top-2{\\r\\n margin-top: var(--cbmis-margin-2) !important;\\r\\n }\\r\\n .cbmis-margin-top-3{\\r\\n margin-top: var(--cbmis-margin-3) !important;\\r\\n }\\r\\n .cbmis-margin-top-4{\\r\\n margin-top: var(--cbmis-margin-4) !important;\\r\\n }\\r\\n .cbmis-margin-top-5{\\r\\n margin-top: var(--cbmis-margin-5) !important;\\r\\n }\\r\\n .cbmis-margin-top-6{\\r\\n margin-top: var(--cbmis-margin-6) !important;\\r\\n }\\r\\n .cbmis-margin-top-7{\\r\\n margin-top: var(--cbmis-margin-7) !important;\\r\\n }\\r\\n .cbmis-margin-top-8{\\r\\n margin-top: var(--cbmis-margin-8) !important;\\r\\n }\\r\\n .cbmis-margin-top-9{\\r\\n margin-top: var(--cbmis-margin-9) !important;\\r\\n }\\r\\n .cbmis-margin-top-10{\\r\\n margin-top: var(--cbmis-margin-10) !important;\\r\\n }\\r\\n .cbmis-margin-top-auto{\\r\\n margin-top: auto !important;\\r\\n }\\r\\n \\r\\n /*margin-left*/\\r\\n .cbmis-margin-left-0{\\r\\n margin-left: var(--cbmis-margin-0) !important;\\r\\n }\\r\\n .cbmis-margin-left-1{\\r\\n margin-left: var(--cbmis-margin-1) !important;\\r\\n }\\r\\n .cbmis-margin-left-2{\\r\\n margin-left: var(--cbmis-margin-2) !important;\\r\\n }\\r\\n .cbmis-margin-left-3{\\r\\n margin-left: var(--cbmis-margin-3) !important;\\r\\n }\\r\\n .cbmis-margin-left-4{\\r\\n margin-left: var(--cbmis-margin-4) !important;\\r\\n }\\r\\n .cbmis-margin-left-5{\\r\\n margin-left: var(--cbmis-margin-5) !important;\\r\\n }\\r\\n .cbmis-margin-left-6{\\r\\n margin-left: var(--cbmis-margin-6) !important;\\r\\n }\\r\\n .cbmis-margin-left-7{\\r\\n margin-left: var(--cbmis-margin-7) !important;\\r\\n }\\r\\n .cbmis-margin-left-8{\\r\\n margin-left: var(--cbmis-margin-8) !important;\\r\\n }\\r\\n .cbmis-margin-left-9{\\r\\n margin-left: var(--cbmis-margin-9) !important;\\r\\n }\\r\\n .cbmis-margin-left-10{\\r\\n margin-left: var(--cbmis-margin-10) !important;\\r\\n }\\r\\n .cbmis-margin-left-auto{\\r\\n margin-left: auto !important;\\r\\n }\\r\\n \\r\\n /*margin-bottom*/\\r\\n .cbmis-margin-bottom-0{\\r\\n margin-bottom: var(--cbmis-margin-0) !important;\\r\\n }\\r\\n .cbmis-margin-bottom-1{\\r\\n margin-bottom: var(--cbmis-margin-1) !important;\\r\\n }\\r\\n .cbmis-margin-bottom-2{\\r\\n margin-bottom: var(--cbmis-margin-2) !important;\\r\\n }\\r\\n .cbmis-margin-bottom-3{\\r\\n margin-bottom: var(--cbmis-margin-3) !important;\\r\\n }\\r\\n .cbmis-margin-bottom-4{\\r\\n margin-bottom: var(--cbmis-margin-4) !important;\\r\\n }\\r\\n .cbmis-margin-bottom-5{\\r\\n margin-bottom: var(--cbmis-margin-5) !important;\\r\\n }\\r\\n .cbmis-margin-bottom-6{\\r\\n margin-bottom: var(--cbmis-margin-6) !important;\\r\\n }\\r\\n .cbmis-margin-bottom-7{\\r\\n margin-bottom: var(--cbmis-margin-7) !important;\\r\\n }\\r\\n .cbmis-margin-bottom-8{\\r\\n margin-bottom: var(--cbmis-margin-8) !important;\\r\\n }\\r\\n .cbmis-margin-bottom-9{\\r\\n margin-bottom: var(--cbmis-margin-9) !important;\\r\\n }\\r\\n .cbmis-margin-bottom-10{\\r\\n margin-bottom: var(--cbmis-margin-10) !important;\\r\\n }\\r\\n .cbmis-margin-bottom-auto{\\r\\n margin-bottom: auto !important;\\r\\n }\\r\\n \\r\\n /*margin-right*/\\r\\n .cbmis-margin-right-0{\\r\\n margin-right: var(--cbmis-margin-0) !important;\\r\\n }\\r\\n .cbmis-margin-right-1{\\r\\n margin-right: var(--cbmis-margin-1) !important;\\r\\n }\\r\\n .cbmis-margin-right-2{\\r\\n margin-right: var(--cbmis-margin-2) !important;\\r\\n }\\r\\n .cbmis-margin-right-3{\\r\\n margin-right: var(--cbmis-margin-3) !important;\\r\\n }\\r\\n .cbmis-margin-right-4{\\r\\n margin-right: var(--cbmis-margin-4) !important;\\r\\n }\\r\\n .cbmis-margin-right-5{\\r\\n margin-right: var(--cbmis-margin-5) !important;\\r\\n }\\r\\n .cbmis-margin-right-6{\\r\\n margin-right: var(--cbmis-margin-6) !important;\\r\\n }\\r\\n .cbmis-margin-right-7{\\r\\n margin-right: var(--cbmis-margin-7) !important;\\r\\n }\\r\\n .cbmis-margin-right-8{\\r\\n margin-right: var(--cbmis-margin-8) !important;\\r\\n }\\r\\n .cbmis-margin-right-9{\\r\\n margin-right: var(--cbmis-margin-9) !important;\\r\\n }\\r\\n .cbmis-margin-right-10{\\r\\n margin-right: var(--cbmis-margin-10) !important;\\r\\n }\\r\\n .cbmis-margin-right-auto{\\r\\n margin-right: auto !important;\\r\\n }\\r\\n \\r\\n /*margin-y*/\\r\\n .cbmis-margin-y-0{\\r\\n margin-top: var(--cbmis-margin-0) !important;\\r\\n margin-bottom: var(--cbmis-margin-0) !important;\\r\\n }\\r\\n .cbmis-margin-y-1{\\r\\n margin-top: var(--cbmis-margin-1) !important;\\r\\n margin-bottom: var(--cbmis-margin-1) !important;\\r\\n }\\r\\n .cbmis-margin-y-2{\\r\\n margin-top: var(--cbmis-margin-2) !important;\\r\\n margin-bottom: var(--cbmis-margin-2) !important;\\r\\n }\\r\\n .cbmis-margin-y-3{\\r\\n margin-top: var(--cbmis-margin-3) !important;\\r\\n margin-bottom: var(--cbmis-margin-3) !important;\\r\\n }\\r\\n .cbmis-margin-y-4{\\r\\n margin-top: var(--cbmis-margin-4) !important;\\r\\n margin-bottom: var(--cbmis-margin-4) !important;\\r\\n }\\r\\n .cbmis-margin-y-5{\\r\\n margin-top: var(--cbmis-margin-5) !important;\\r\\n margin-bottom: var(--cbmis-margin-5) !important;\\r\\n }\\r\\n .cbmis-margin-y-6{\\r\\n margin-top: var(--cbmis-margin-6) !important;\\r\\n margin-bottom: var(--cbmis-margin-6) !important;\\r\\n }\\r\\n .cbmis-margin-y-7{\\r\\n margin-top: var(--cbmis-margin-7) !important;\\r\\n margin-bottom: var(--cbmis-margin-7) !important;\\r\\n }\\r\\n .cbmis-margin-y-8{\\r\\n margin-top: var(--cbmis-margin-8) !important;\\r\\n margin-bottom: var(--cbmis-margin-8) !important;\\r\\n }\\r\\n .cbmis-margin-y-9{\\r\\n margin-top: var(--cbmis-margin-9) !important;\\r\\n margin-bottom: var(--cbmis-margin-9) !important;\\r\\n }\\r\\n .cbmis-margin-y-10{\\r\\n margin-top: var(--cbmis-margin-10) !important;\\r\\n margin-bottom: var(--cbmis-margin-10) !important;\\r\\n }\\r\\n .cbmis-margin-y-auto{\\r\\n margin-top: auto !important;\\r\\n margin-bottom: auto !important;\\r\\n }\\r\\n \\r\\n /*margin-x*/\\r\\n .cbmis-margin-x-0{\\r\\n margin-left: var(--cbmis-margin-0) !important;\\r\\n margin-bottom: var(--cbmis-margin-0) !important;\\r\\n }\\r\\n .cbmis-margin-x-1{\\r\\n margin-left: var(--cbmis-margin-1) !important;\\r\\n margin-right: var(--cbmis-margin-1) !important;\\r\\n }\\r\\n .cbmis-margin-x-2{\\r\\n margin-left: var(--cbmis-margin-2) !important;\\r\\n margin-right: var(--cbmis-margin-2) !important;\\r\\n }\\r\\n .cbmis-margin-x-3{\\r\\n margin-left: var(--cbmis-margin-3) !important;\\r\\n margin-right: var(--cbmis-margin-3) !important;\\r\\n }\\r\\n .cbmis-margin-x-4{\\r\\n margin-left: var(--cbmis-margin-4) !important;\\r\\n margin-right: var(--cbmis-margin-4) !important;\\r\\n }\\r\\n .cbmis-margin-x-5{\\r\\n margin-left: var(--cbmis-margin-5) !important;\\r\\n margin-right: var(--cbmis-margin-5) !important;\\r\\n }\\r\\n .cbmis-margin-x-6{\\r\\n margin-left: var(--cbmis-margin-6) !important;\\r\\n margin-right: var(--cbmis-margin-6) !important;\\r\\n }\\r\\n .cbmis-margin-x-7{\\r\\n margin-left: var(--cbmis-margin-7) !important;\\r\\n margin-right: var(--cbmis-margin-7) !important;\\r\\n }\\r\\n .cbmis-margin-x-8{\\r\\n margin-left: var(--cbmis-margin-8) !important;\\r\\n margin-right: var(--cbmis-margin-8) !important;\\r\\n }\\r\\n .cbmis-margin-x-9{\\r\\n margin-left: var(--cbmis-margin-9) !important;\\r\\n margin-right: var(--cbmis-margin-9) !important;\\r\\n }\\r\\n .cbmis-margin-x-10{\\r\\n margin-left: var(--cbmis-margin-10) !important;\\r\\n margin-right: var(--cbmis-margin-10) !important;\\r\\n }\\r\\n .cbmis-margin-x-auto{\\r\\n margin-left: auto !important;\\r\\n margin-right: auto !important;\\r\\n }\\r\\n \\r\\n /*padding*/\\r\\n .cbmis-padding-0{\\r\\n padding: var(--cbmis-padding-0) !important;\\r\\n }\\r\\n .cbmis-padding-1{\\r\\n padding: var(--cbmis-padding-1) !important;\\r\\n }\\r\\n .cbmis-padding-2{\\r\\n padding: var(--cbmis-padding-2) !important;\\r\\n }\\r\\n .cbmis-padding-3{\\r\\n padding: var(--cbmis-padding-3) !important;\\r\\n }\\r\\n .cbmis-padding-4{\\r\\n padding: var(--cbmis-padding-4) !important;\\r\\n }\\r\\n .cbmis-padding-5{\\r\\n padding: var(--cbmis-padding-5) !important;\\r\\n }\\r\\n .cbmis-padding-6{\\r\\n padding: var(--cbmis-padding-6) !important;\\r\\n }\\r\\n .cbmis-padding-7{\\r\\n padding: var(--cbmis-padding-7) !important;\\r\\n }\\r\\n .cbmis-padding-8{\\r\\n padding: var(--cbmis-padding-8) !important;\\r\\n }\\r\\n .cbmis-padding-9{\\r\\n padding: var(--cbmis-padding-9) !important;\\r\\n }\\r\\n .cbmis-padding-10{\\r\\n padding: var(--cbmis-padding-10) !important;\\r\\n }\\r\\n .cbmis-padding-auto{\\r\\n padding: auto !important;\\r\\n }\\r\\n \\r\\n /*padding-top*/\\r\\n .cbmis-padding-top-0{\\r\\n padding-top: var(--cbmis-padding-0) !important;\\r\\n }\\r\\n .cbmis-padding-top-1{\\r\\n padding-top: var(--cbmis-padding-1) !important;\\r\\n }\\r\\n .cbmis-padding-top-2{\\r\\n padding-top: var(--cbmis-padding-2) !important;\\r\\n }\\r\\n .cbmis-padding-top-3{\\r\\n padding-top: var(--cbmis-padding-3) !important;\\r\\n }\\r\\n .cbmis-padding-top-4{\\r\\n padding-top: var(--cbmis-padding-4) !important;\\r\\n }\\r\\n .cbmis-padding-top-5{\\r\\n padding-top: var(--cbmis-padding-5) !important;\\r\\n }\\r\\n .cbmis-padding-top-6{\\r\\n padding-top: var(--cbmis-padding-6) !important;\\r\\n }\\r\\n .cbmis-padding-top-7{\\r\\n padding-top: var(--cbmis-padding-7) !important;\\r\\n }\\r\\n .cbmis-padding-top-8{\\r\\n padding-top: var(--cbmis-padding-8) !important;\\r\\n }\\r\\n .cbmis-padding-top-9{\\r\\n padding-top: var(--cbmis-padding-9) !important;\\r\\n }\\r\\n .cbmis-padding-top-10{\\r\\n padding-top: var(--cbmis-padding-10) !important;\\r\\n }\\r\\n .cbmis-padding-top-auto{\\r\\n padding-top: auto !important;\\r\\n }\\r\\n /*padding-left*/\\r\\n .cbmis-padding-left-0{\\r\\n padding-left: var(--cbmis-padding-0) !important;\\r\\n }\\r\\n .cbmis-padding-left-1{\\r\\n padding-left: var(--cbmis-padding-1) !important;\\r\\n }\\r\\n .cbmis-padding-left-2{\\r\\n padding-left: var(--cbmis-padding-2) !important;\\r\\n }\\r\\n .cbmis-padding-left-3{\\r\\n padding-left: var(--cbmis-padding-3) !important;\\r\\n }\\r\\n .cbmis-padding-left-4{\\r\\n padding-left: var(--cbmis-padding-4) !important;\\r\\n }\\r\\n .cbmis-padding-left-5{\\r\\n padding-left: var(--cbmis-padding-5) !important;\\r\\n }\\r\\n .cbmis-padding-left-6{\\r\\n padding-left: var(--cbmis-padding-6) !important;\\r\\n }\\r\\n .cbmis-padding-left-7{\\r\\n padding-left: var(--cbmis-padding-7) !important;\\r\\n }\\r\\n .cbmis-padding-left-8{\\r\\n padding-left: var(--cbmis-padding-8) !important;\\r\\n }\\r\\n .cbmis-padding-left-9{\\r\\n padding-left: var(--cbmis-padding-9) !important;\\r\\n }\\r\\n .cbmis-padding-left-10{\\r\\n padding-left: var(--cbmis-padding-10) !important;\\r\\n }\\r\\n .cbmis-padding-left-auto{\\r\\n padding-left: auto !important;\\r\\n }\\r\\n \\r\\n /*padding-bottom*/\\r\\n .cbmis-padding-bottom-0{\\r\\n padding-bottom: var(--cbmis-padding-0) !important;\\r\\n }\\r\\n .cbmis-padding-bottom-1{\\r\\n padding-bottom: var(--cbmis-padding-1) !important;\\r\\n }\\r\\n .cbmis-padding-bottom-2{\\r\\n padding-bottom: var(--cbmis-padding-2) !important;\\r\\n }\\r\\n .cbmis-padding-bottom-3{\\r\\n padding-bottom: var(--cbmis-padding-3) !important;\\r\\n }\\r\\n .cbmis-padding-bottom-4{\\r\\n padding-bottom: var(--cbmis-padding-4) !important;\\r\\n }\\r\\n .cbmis-padding-bottom-5{\\r\\n padding-bottom: var(--cbmis-padding-5) !important;\\r\\n }\\r\\n .cbmis-padding-bottom-6{\\r\\n padding-bottom: var(--cbmis-padding-6) !important;\\r\\n }\\r\\n .cbmis-padding-bottom-7{\\r\\n padding-bottom: var(--cbmis-padding-7) !important;\\r\\n }\\r\\n .cbmis-padding-bottom-8{\\r\\n padding-bottom: var(--cbmis-padding-8) !important;\\r\\n }\\r\\n .cbmis-padding-bottom-9{\\r\\n padding-bottom: var(--cbmis-padding-9) !important;\\r\\n }\\r\\n .cbmis-padding-bottom-10{\\r\\n padding-bottom: var(--cbmis-padding-10) !important;\\r\\n }\\r\\n .cbmis-padding-bottom-auto{\\r\\n padding-bottom: auto !important;\\r\\n }\\r\\n \\r\\n /*padding-right*/\\r\\n .cbmis-padding-right-0{\\r\\n padding-right: var(--cbmis-padding-0) !important;\\r\\n }\\r\\n .cbmis-padding-right-1{\\r\\n padding-right: var(--cbmis-padding-1) !important;\\r\\n }\\r\\n .cbmis-padding-right-2{\\r\\n padding-right: var(--cbmis-padding-2) !important;\\r\\n }\\r\\n .cbmis-padding-right-3{\\r\\n padding-right: var(--cbmis-padding-3) !important;\\r\\n }\\r\\n .cbmis-padding-right-4{\\r\\n padding-right: var(--cbmis-padding-4) !important;\\r\\n }\\r\\n .cbmis-padding-right-5{\\r\\n padding-right: var(--cbmis-padding-5) !important;\\r\\n }\\r\\n .cbmis-padding-right-6{\\r\\n padding-right: var(--cbmis-padding-6) !important;\\r\\n }\\r\\n .cbmis-padding-right-7{\\r\\n padding-right: var(--cbmis-padding-7) !important;\\r\\n }\\r\\n .cbmis-padding-right-8{\\r\\n padding-right: var(--cbmis-padding-8) !important;\\r\\n }\\r\\n .cbmis-padding-right-9{\\r\\n padding-right: var(--cbmis-padding-9) !important;\\r\\n }\\r\\n .cbmis-padding-right-10{\\r\\n padding-right: var(--cbmis-padding-10) !important;\\r\\n }\\r\\n .cbmis-padding-right-auto{\\r\\n padding-right: auto !important;\\r\\n }\\r\\n \\r\\n /*padding-y*/\\r\\n .cbmis-padding-y-0{\\r\\n padding-top: var(--cbmis-padding-0) !important;\\r\\n padding-bottom: var(--cbmis-padding-0) !important;\\r\\n }\\r\\n .cbmis-padding-y-1{\\r\\n padding-top: var(--cbmis-padding-1) !important;\\r\\n padding-bottom: var(--cbmis-padding-1) !important;\\r\\n }\\r\\n .cbmis-padding-y-2{\\r\\n padding-top: var(--cbmis-padding-2) !important;\\r\\n padding-bottom: var(--cbmis-padding-2) !important;\\r\\n }\\r\\n .cbmis-padding-y-3{\\r\\n padding-top: var(--cbmis-padding-3) !important;\\r\\n padding-bottom: var(--cbmis-padding-3) !important;\\r\\n }\\r\\n .cbmis-padding-y-4{\\r\\n padding-top: var(--cbmis-padding-4) !important;\\r\\n padding-bottom: var(--cbmis-padding-4) !important;\\r\\n }\\r\\n .cbmis-padding-y-5{\\r\\n padding-top: var(--cbmis-padding-5) !important;\\r\\n padding-bottom: var(--cbmis-padding-5) !important;\\r\\n }\\r\\n .cbmis-padding-y-6{\\r\\n padding-top: var(--cbmis-padding-6) !important;\\r\\n padding-bottom: var(--cbmis-padding-6) !important;\\r\\n }\\r\\n .cbmis-padding-y-7{\\r\\n padding-top: var(--cbmis-padding-7) !important;\\r\\n padding-bottom: var(--cbmis-padding-7) !important;\\r\\n }\\r\\n .cbmis-padding-y-8{\\r\\n padding-top: var(--cbmis-padding-8) !important;\\r\\n padding-bottom: var(--cbmis-padding-8) !important;\\r\\n }\\r\\n .cbmis-padding-y-9{\\r\\n padding-top: var(--cbmis-padding-9) !important;\\r\\n padding-bottom: var(--cbmis-padding-9) !important;\\r\\n }\\r\\n .cbmis-padding-y-10{\\r\\n padding-top: var(--cbmis-padding-10) !important;\\r\\n padding-bottom: var(--cbmis-padding-10) !important;\\r\\n }\\r\\n .cbmis-padding-y-auto{\\r\\n padding-top: auto !important;\\r\\n padding-bottom: auto !important;\\r\\n }\\r\\n \\r\\n /*padding-x*/\\r\\n .cbmis-padding-x-0{\\r\\n padding-left: var(--cbmis-padding-0) !important;\\r\\n padding-bottom: var(--cbmis-padding-0) !important;\\r\\n }\\r\\n .cbmis-padding-x-1{\\r\\n padding-left: var(--cbmis-padding-1) !important;\\r\\n padding-right: var(--cbmis-padding-1) !important;\\r\\n }\\r\\n .cbmis-padding-x-2{\\r\\n padding-left: var(--cbmis-padding-2) !important;\\r\\n padding-right: var(--cbmis-padding-2) !important;\\r\\n }\\r\\n .cbmis-padding-x-3{\\r\\n padding-left: var(--cbmis-padding-3) !important;\\r\\n padding-right: var(--cbmis-padding-3) !important;\\r\\n }\\r\\n .cbmis-padding-x-4{\\r\\n padding-left: var(--cbmis-padding-4) !important;\\r\\n padding-right: var(--cbmis-padding-4) !important;\\r\\n }\\r\\n .cbmis-padding-x-5{\\r\\n padding-left: var(--cbmis-padding-5) !important;\\r\\n padding-right: var(--cbmis-padding-5) !important;\\r\\n }\\r\\n .cbmis-padding-x-6{\\r\\n padding-left: var(--cbmis-padding-6) !important;\\r\\n padding-right: var(--cbmis-padding-6) !important;\\r\\n }\\r\\n .cbmis-padding-x-7{\\r\\n padding-left: var(--cbmis-padding-7) !important;\\r\\n padding-right: var(--cbmis-padding-7) !important;\\r\\n }\\r\\n .cbmis-padding-x-8{\\r\\n padding-left: var(--cbmis-padding-8) !important;\\r\\n padding-right: var(--cbmis-padding-8) !important;\\r\\n }\\r\\n .cbmis-padding-x-9{\\r\\n padding-left: var(--cbmis-padding-9) !important;\\r\\n padding-right: var(--cbmis-padding-9) !important;\\r\\n }\\r\\n .cbmis-padding-x-10{\\r\\n padding-left: var(--cbmis-padding-10) !important;\\r\\n padding-right: var(--cbmis-padding-10) !important;\\r\\n }\\r\\n \\r\\n .cbmis-padding-x-auto{\\r\\n padding-left: auto !important;\\r\\n padding-right: auto !important;\\r\\n }\\r\\n \\r\\n\\r\\n /* **************************************** hidden ******************************************* */\\r\\n\\r\\n .cbmis-invisible-hidden ,.cbmis-invisible-hidden>*{\\r\\n visibility: hidden !important;\\r\\n opacity: 0 !important;\\r\\n z-index: var(--cbmis-z-index-0) !important;\\r\\n width: 0 !important;\\r\\n height: 0 !important;\\r\\n padding: 0 !important;\\r\\n margin: 0 !important;\\r\\n border-width: 0 !important;\\r\\n position: fixed !important;\\r\\n top: 0 !important;\\r\\n display: none !important;\\r\\n }\\r\\n\\r\\n /* **************************************** scrollbar ******************************************* */\\r\\n \\r\\n /* width */\\r\\n ::-webkit-scrollbar {\\r\\n width: 10px;\\r\\n }\\r\\n \\r\\n /* Track */\\r\\n ::-webkit-scrollbar-track {\\r\\n background: transparent;\\r\\n border:solid var(--cbmis-secondary-200);\\r\\n border-width: 0 1px;\\r\\n }\\r\\n\\r\\n /* Handle */\\r\\n ::-webkit-scrollbar-thumb {\\r\\n background: var(--cbmis-secondary-500); \\r\\n opacity: .5;\\r\\n }\\r\\n\\r\\n /* Handle on hover */\\r\\n ::-webkit-scrollbar-thumb:hover {\\r\\n background: var(--cbmis-secondary-700);\\r\\n opacity: .5;\\r\\n }\\r\\n\\r\\n @media only screen and (max-width: 576px) {\\r\\n ::-webkit-scrollbar{\\r\\n position: absolute;\\r\\n width: 0 !important;\\r\\n height: 0 !important;\\r\\n opacity: 0 !important;\\r\\n }\\r\\n ::-webkit-scrollbar-track {\\r\\n opacity: 0;\\r\\n visibility: hidden;\\r\\n background: transparent;\\r\\n }\\r\\n ::-webkit-scrollbar-thumb ,::-webkit-scrollbar-thumb:hover{\\r\\n opacity: 0;\\r\\n visibility: hidden;\\r\\n background: transparent;\\r\\n }\\r\\n }\\r\\n\\r\\n .cbmis-border-radius-pill{\\r\\n border-radius: var(--cbmis-border-radius-pill) !important;\\r\\n }\", \"\",{\"version\":3,\"sources\":[\"webpack://./style/src/style/main.css\"],\"names\":[],\"mappings\":\"AAAA,uBAAuB;;AAGvB;IACI,8BAA8B;IAC9B,+BAA+B;IAC/B,kCAAkC;IAClC,iCAAiC;IACjC,2CAA2C;IAC3C,qCAAqC;IACrC,gCAAgC;;;IAGhC,kCAAkC;IAClC,8BAA8B;EAChC;;AAEF;IACI;;;;;;;;;;;;MAYE;;KAED,cAAc;KACd,yBAAyB;KACzB;AACL;;AAEA,UAAU;EACR;MACI,uCAAuC;EAC3C;EACA;MACI,uCAAuC;EAC3C;EACA;MACI,uCAAuC;EAC3C;EACA;MACI,uCAAuC;EAC3C;EACA;MACI,uCAAuC;EAC3C;EACA;MACI,0CAA0C;EAC9C;EACA;MACI,yCAAyC;EAC7C;;;EAGA;IACE,YAAY;EACd;EACA;IACE,mEAAmE;EACrE;EACA;IACE,mEAAmE;EACrE;EACA;IACE,mEAAmE;EACrE;EACA;IACE,mEAAmE;EACrE;EACA;IACE,mEAAmE;EACrE;;CAED,QAAQ;EACP;IACE,8CAA8C;EAChD;EACA;IACE,sCAAsC;EACxC;EACA;IACE,4CAA4C;EAC9C;EACA;IACE,4CAA4C;IAC5C,8BAA8B;;IAE9B,uDAAuD;IACvD,sDAAsD;IACtD,sCAAsC;IACtC,qCAAqC;IACrC,qCAAqC;IACrC,wCAAwC;IACxC,sCAAsC;EACxC;EACA;IACE,0CAA0C;EAC5C;EACA;IACE,yCAAyC;EAC3C;EACA;IACE,0CAA0C;EAC5C;EACA;IACE,yCAAyC;EAC3C;EACA;IACE,sCAAsC;EACxC;EACA;IACE,6CAA6C;EAC/C;EACA;IACE,8CAA8C;EAChD;EACA;IACE,gDAAgD;EAClD;EACA;IACE,+CAA+C;EACjD;;EAEA,SAAS;EACT;IACE,wCAAwC;EAC1C;EACA;IACE,wCAAwC;EAC1C;EACA;IACE,wCAAwC;EAC1C;EACA;IACE,wCAAwC;EAC1C;EACA;IACE,wCAAwC;EAC1C;EACA;IACE,wCAAwC;EAC1C;EACA;IACE,wCAAwC;EAC1C;EACA;IACE,wCAAwC;EAC1C;EACA;IACE,wCAAwC;EAC1C;EACA;IACE,wCAAwC;EAC1C;EACA;IACE,yCAAyC;EAC3C;EACA;IACE,uBAAuB;EACzB;;EAEA,aAAa;EACb;IACE,4CAA4C;EAC9C;EACA;IACE,4CAA4C;EAC9C;EACA;IACE,4CAA4C;EAC9C;EACA;IACE,4CAA4C;EAC9C;EACA;IACE,4CAA4C;EAC9C;EACA;IACE,4CAA4C;EAC9C;EACA;IACE,4CAA4C;EAC9C;EACA;IACE,4CAA4C;EAC9C;EACA;IACE,4CAA4C;EAC9C;EACA;IACE,4CAA4C;EAC9C;EACA;IACE,6CAA6C;EAC/C;EACA;IACE,2BAA2B;EAC7B;;EAEA,cAAc;EACd;IACE,6CAA6C;EAC/C;EACA;IACE,6CAA6C;EAC/C;EACA;IACE,6CAA6C;EAC/C;EACA;IACE,6CAA6C;EAC/C;EACA;IACE,6CAA6C;EAC/C;EACA;IACE,6CAA6C;EAC/C;EACA;IACE,6CAA6C;EAC/C;EACA;IACE,6CAA6C;EAC/C;EACA;IACE,6CAA6C;EAC/C;EACA;IACE,6CAA6C;EAC/C;EACA;IACE,8CAA8C;EAChD;EACA;IACE,4BAA4B;EAC9B;;EAEA,gBAAgB;EAChB;IACE,+CAA+C;EACjD;EACA;IACE,+CAA+C;EACjD;EACA;IACE,+CAA+C;EACjD;EACA;IACE,+CAA+C;EACjD;EACA;IACE,+CAA+C;EACjD;EACA;IACE,+CAA+C;EACjD;EACA;IACE,+CAA+C;EACjD;EACA;IACE,+CAA+C;EACjD;EACA;IACE,+CAA+C;EACjD;EACA;IACE,+CAA+C;EACjD;EACA;IACE,gDAAgD;EAClD;EACA;IACE,8BAA8B;EAChC;;EAEA,eAAe;EACf;IACE,8CAA8C;EAChD;EACA;IACE,8CAA8C;EAChD;EACA;IACE,8CAA8C;EAChD;EACA;IACE,8CAA8C;EAChD;EACA;IACE,8CAA8C;EAChD;EACA;IACE,8CAA8C;EAChD;EACA;IACE,8CAA8C;EAChD;EACA;IACE,8CAA8C;EAChD;EACA;IACE,8CAA8C;EAChD;EACA;IACE,8CAA8C;EAChD;EACA;IACE,+CAA+C;EACjD;EACA;IACE,6BAA6B;EAC/B;;EAEA,WAAW;EACX;IACE,4CAA4C;IAC5C,+CAA+C;EACjD;EACA;IACE,4CAA4C;IAC5C,+CAA+C;EACjD;EACA;IACE,4CAA4C;IAC5C,+CAA+C;EACjD;EACA;IACE,4CAA4C;IAC5C,+CAA+C;EACjD;EACA;IACE,4CAA4C;IAC5C,+CAA+C;EACjD;EACA;IACE,4CAA4C;IAC5C,+CAA+C;EACjD;EACA;IACE,4CAA4C;IAC5C,+CAA+C;EACjD;EACA;IACE,4CAA4C;IAC5C,+CAA+C;EACjD;EACA;IACE,4CAA4C;IAC5C,+CAA+C;EACjD;EACA;IACE,4CAA4C;IAC5C,+CAA+C;EACjD;EACA;IACE,6CAA6C;IAC7C,gDAAgD;EAClD;EACA;IACE,2BAA2B;IAC3B,8BAA8B;EAChC;;EAEA,WAAW;EACX;IACE,6CAA6C;IAC7C,+CAA+C;EACjD;EACA;IACE,6CAA6C;IAC7C,8CAA8C;EAChD;EACA;IACE,6CAA6C;IAC7C,8CAA8C;EAChD;EACA;IACE,6CAA6C;IAC7C,8CAA8C;EAChD;EACA;IACE,6CAA6C;IAC7C,8CAA8C;EAChD;EACA;IACE,6CAA6C;IAC7C,8CAA8C;EAChD;EACA;IACE,6CAA6C;IAC7C,8CAA8C;EAChD;EACA;IACE,6CAA6C;IAC7C,8CAA8C;EAChD;EACA;IACE,6CAA6C;IAC7C,8CAA8C;EAChD;EACA;IACE,6CAA6C;IAC7C,8CAA8C;EAChD;EACA;IACE,8CAA8C;IAC9C,+CAA+C;EACjD;EACA;IACE,4BAA4B;IAC5B,6BAA6B;EAC/B;;EAEA,UAAU;EACV;IACE,0CAA0C;EAC5C;EACA;IACE,0CAA0C;EAC5C;EACA;IACE,0CAA0C;EAC5C;EACA;IACE,0CAA0C;EAC5C;EACA;IACE,0CAA0C;EAC5C;EACA;IACE,0CAA0C;EAC5C;EACA;IACE,0CAA0C;EAC5C;EACA;IACE,0CAA0C;EAC5C;EACA;IACE,0CAA0C;EAC5C;EACA;IACE,0CAA0C;EAC5C;EACA;IACE,2CAA2C;EAC7C;EACA;IACE,wBAAwB;EAC1B;;EAEA,cAAc;EACd;IACE,8CAA8C;EAChD;EACA;IACE,8CAA8C;EAChD;EACA;IACE,8CAA8C;EAChD;EACA;IACE,8CAA8C;EAChD;EACA;IACE,8CAA8C;EAChD;EACA;IACE,8CAA8C;EAChD;EACA;IACE,8CAA8C;EAChD;EACA;IACE,8CAA8C;EAChD;EACA;IACE,8CAA8C;EAChD;EACA;IACE,8CAA8C;EAChD;EACA;IACE,+CAA+C;EACjD;EACA;IACE,4BAA4B;EAC9B;EACA,eAAe;EACf;IACE,+CAA+C;EACjD;EACA;IACE,+CAA+C;EACjD;EACA;IACE,+CAA+C;EACjD;EACA;IACE,+CAA+C;EACjD;EACA;IACE,+CAA+C;EACjD;EACA;IACE,+CAA+C;EACjD;EACA;IACE,+CAA+C;EACjD;EACA;IACE,+CAA+C;EACjD;EACA;IACE,+CAA+C;EACjD;EACA;IACE,+CAA+C;EACjD;EACA;IACE,gDAAgD;EAClD;EACA;IACE,6BAA6B;EAC/B;;EAEA,iBAAiB;EACjB;IACE,iDAAiD;EACnD;EACA;IACE,iDAAiD;EACnD;EACA;IACE,iDAAiD;EACnD;EACA;IACE,iDAAiD;EACnD;EACA;IACE,iDAAiD;EACnD;EACA;IACE,iDAAiD;EACnD;EACA;IACE,iDAAiD;EACnD;EACA;IACE,iDAAiD;EACnD;EACA;IACE,iDAAiD;EACnD;EACA;IACE,iDAAiD;EACnD;EACA;IACE,kDAAkD;EACpD;EACA;IACE,+BAA+B;EACjC;;EAEA,gBAAgB;EAChB;IACE,gDAAgD;EAClD;EACA;IACE,gDAAgD;EAClD;EACA;IACE,gDAAgD;EAClD;EACA;IACE,gDAAgD;EAClD;EACA;IACE,gDAAgD;EAClD;EACA;IACE,gDAAgD;EAClD;EACA;IACE,gDAAgD;EAClD;EACA;IACE,gDAAgD;EAClD;EACA;IACE,gDAAgD;EAClD;EACA;IACE,gDAAgD;EAClD;EACA;IACE,iDAAiD;EACnD;EACA;IACE,8BAA8B;EAChC;;EAEA,YAAY;EACZ;IACE,8CAA8C;IAC9C,iDAAiD;EACnD;EACA;IACE,8CAA8C;IAC9C,iDAAiD;EACnD;EACA;IACE,8CAA8C;IAC9C,iDAAiD;EACnD;EACA;IACE,8CAA8C;IAC9C,iDAAiD;EACnD;EACA;IACE,8CAA8C;IAC9C,iDAAiD;EACnD;EACA;IACE,8CAA8C;IAC9C,iDAAiD;EACnD;EACA;IACE,8CAA8C;IAC9C,iDAAiD;EACnD;EACA;IACE,8CAA8C;IAC9C,iDAAiD;EACnD;EACA;IACE,8CAA8C;IAC9C,iDAAiD;EACnD;EACA;IACE,8CAA8C;IAC9C,iDAAiD;EACnD;EACA;IACE,+CAA+C;IAC/C,kDAAkD;EACpD;EACA;IACE,4BAA4B;IAC5B,+BAA+B;EACjC;;EAEA,YAAY;EACZ;IACE,+CAA+C;IAC/C,iDAAiD;EACnD;EACA;IACE,+CAA+C;IAC/C,gDAAgD;EAClD;EACA;IACE,+CAA+C;IAC/C,gDAAgD;EAClD;EACA;IACE,+CAA+C;IAC/C,gDAAgD;EAClD;EACA;IACE,+CAA+C;IAC/C,gDAAgD;EAClD;EACA;IACE,+CAA+C;IAC/C,gDAAgD;EAClD;EACA;IACE,+CAA+C;IAC/C,gDAAgD;EAClD;EACA;IACE,+CAA+C;IAC/C,gDAAgD;EAClD;EACA;IACE,+CAA+C;IAC/C,gDAAgD;EAClD;EACA;IACE,+CAA+C;IAC/C,gDAAgD;EAClD;EACA;IACE,gDAAgD;IAChD,iDAAiD;EACnD;;EAEA;IACE,6BAA6B;IAC7B,8BAA8B;EAChC;;;IAGE,gGAAgG;;EAElG;IACE,6BAA6B;IAC7B,qBAAqB;IACrB,0CAA0C;IAC1C,mBAAmB;IACnB,oBAAoB;IACpB,qBAAqB;IACrB,oBAAoB;IACpB,0BAA0B;IAC1B,0BAA0B;IAC1B,iBAAiB;IACjB,wBAAwB;EAC1B;;EAEA,mGAAmG;;EAEnG,UAAU;EACV;IACE,WAAW;EACb;;EAEA,UAAU;EACV;IACE,uBAAuB;IACvB,uCAAuC;IACvC,mBAAmB;EACrB;;EAEA,WAAW;EACX;IACE,sCAAsC;IACtC,WAAW;EACb;;EAEA,oBAAoB;EACpB;IACE,sCAAsC;IACtC,WAAW;EACb;;EAEA;IACE;MACE,kBAAkB;MAClB,mBAAmB;MACnB,oBAAoB;MACpB,qBAAqB;IACvB;IACA;MACE,UAAU;MACV,kBAAkB;MAClB,uBAAuB;IACzB;IACA;MACE,UAAU;MACV,kBAAkB;MAClB,uBAAuB;IACzB;EACF;;EAEA;IACE,yDAAyD;EAC3D\",\"sourcesContent\":[\"/* @import-normalize; */\\r\\n@import url(\\\"var.css\\\");\\r\\n\\r\\n*{\\r\\n font-family: \\\"Poppins\\\", roboto;\\r\\n font-family: 'Satisfy', cursive;\\r\\n font-family: 'Cairo Play', cursive;\\r\\n font-family: 'Changa', sans-serif;\\r\\n font-family: 'Almarai', 'Cairo', sans-serif;\\r\\n /* font-family: 'Mada', sans-serif; */\\r\\n font-family: 'Cairo', sans-serif;\\r\\n\\r\\n\\r\\n margin: var(--cbmis-spacer-0) auto;\\r\\n padding: var(--cbmis-spacer-0);\\r\\n }\\r\\n\\r\\nbody{\\r\\n /* margin: var(--cbmis-spacer-0);\\r\\n padding: var(--cbmis-spacer-0);\\r\\n height: 100vh;\\r\\n width: 100wh;\\r\\n margin: var(--cbmis-spacer-0);\\r\\n color: #111;\\r\\n font-size: var(--cbmis-body-font-size);\\r\\n line-height: var(--cbmis-body-line-height);\\r\\n letter-spacing: var(--cbmis-spacer-0);\\r\\n font-weight: var(--cbmis-body-font-weight);\\r\\n scroll-margin-top: calc(var(--MuiDocs-header-height) + 32px);\\r\\n background: var(--cbmis-white);\\r\\n */\\r\\n\\r\\n color: #374151;\\r\\n background-color: #f6f6f6;\\r\\n overflow-x:hidden\\r\\n}\\r\\n\\r\\n/* width */\\r\\n .cbmis-width-xl{\\r\\n width: var(--cbmis-width-xl) !important;\\r\\n }\\r\\n .cbmis-width-lg{\\r\\n width: var(--cbmis-width-lg) !important;\\r\\n }\\r\\n .cbmis-width-md{\\r\\n width: var(--cbmis-width-md) !important;\\r\\n }\\r\\n .cbmis-width-sm{\\r\\n width: var(--cbmis-width-sm) !important;\\r\\n }\\r\\n .cbmis-width-xs{\\r\\n width: var(--cbmis-width-xs) !important;\\r\\n }\\r\\n .cbmis-width-fluid{\\r\\n width: var(--cbmis-width-fluid) !important;\\r\\n }\\r\\n .cbmis-width-half{\\r\\n width: var(--cbmis-width-half) !important;\\r\\n }\\r\\n\\r\\n\\r\\n .cbmis-border-width-0{\\r\\n border: none;\\r\\n }\\r\\n .cbmis-border-width-1{\\r\\n border: var(--cbmis-border-width-1) solid var(--cbmis-border-color);\\r\\n }\\r\\n .cbmis-border-width-2{\\r\\n border: var(--cbmis-border-width-2) solid var(--cbmis-border-color);\\r\\n }\\r\\n .cbmis-border-width-3{\\r\\n border: var(--cbmis-border-width-3) solid var(--cbmis-border-color);\\r\\n }\\r\\n .cbmis-border-width-4{\\r\\n border: var(--cbmis-border-width-4) solid var(--cbmis-border-color);\\r\\n }\\r\\n .cbmis-border-width-5{\\r\\n border: var(--cbmis-border-width-5) solid var(--cbmis-border-color);\\r\\n }\\r\\n\\r\\n /*shape*/\\r\\n .cbmis-shape-circle{\\r\\n border-radius: var(--cbmis-border-radius-pill);\\r\\n }\\r\\n .cbmis-shape-oval{\\r\\n clip-path: var(--cbmis-clip-path-oval);\\r\\n }\\r\\n .cbmis-shape-square{\\r\\n border-radius: var(--cbmis-border-radius-md);\\r\\n }\\r\\n .cbmis-shape-rectangle{\\r\\n border-radius: var(--cbmis-border-radius-md);\\r\\n padding: 0 var(--cbmis-spacer);\\r\\n\\r\\n --cbmis-width-item-xs: calc(var(--cbmis-spacer-4) /1.2);\\r\\n --cbmis-width-item-sm: calc(var(--cbmis-spacer-5)/1.2);\\r\\n --cbmis-width-item-md: calc(4rem /1.2);\\r\\n --cbmis-width-item-lg: calc(5rem/1.2);\\r\\n --cbmis-width-item-xl: calc(6rem/1.2);\\r\\n --cbmis-width-item-fluid: calc(100%/1.2);\\r\\n --cbmis-width-item-half:calc(50% /1.2);\\r\\n }\\r\\n .cbmis-shape-pentagon{\\r\\n clip-path: var(--cbmis-clip-path-pentagon);\\r\\n }\\r\\n .cbmis-shape-hexagon{\\r\\n clip-path: var(--cbmis-clip-path-hexagon);\\r\\n }\\r\\n .cbmis-shape-heptagon{\\r\\n clip-path: var(--cbmis-clip-path-heptagon);\\r\\n }\\r\\n .cbmis-shape-octagon{\\r\\n clip-path: var(--cbmis-clip-path-octagon);\\r\\n }\\r\\n .cbmis-shape-star{\\r\\n clip-path: var(--cbmis-clip-path-star);\\r\\n }\\r\\n .cbmis-shape-top-chevron{\\r\\n clip-path: var(--cbmis-clip-path-top-chevron);\\r\\n }\\r\\n .cbmis-shape-left-chevron{\\r\\n clip-path: var(--cbmis-clip-path-left-chevron);\\r\\n }\\r\\n .cbmis-shape-bottom-chevron{\\r\\n clip-path: var(--cbmis-clip-path-bottom-chevron);\\r\\n }\\r\\n .cbmis-shape-right-chevron{\\r\\n clip-path: var(--cbmis-clip-path-right-chevron);\\r\\n }\\r\\n \\r\\n /*margin*/\\r\\n .cbmis-margin-0{\\r\\n margin: var(--cbmis-margin-0) !important;\\r\\n }\\r\\n .cbmis-margin-1{\\r\\n margin: var(--cbmis-margin-1) !important;\\r\\n }\\r\\n .cbmis-margin-2{\\r\\n margin: var(--cbmis-margin-2) !important;\\r\\n }\\r\\n .cbmis-margin-3{\\r\\n margin: var(--cbmis-margin-3) !important;\\r\\n }\\r\\n .cbmis-margin-4{\\r\\n margin: var(--cbmis-margin-4) !important;\\r\\n }\\r\\n .cbmis-margin-5{\\r\\n margin: var(--cbmis-margin-5) !important;\\r\\n }\\r\\n .cbmis-margin-6{\\r\\n margin: var(--cbmis-margin-6) !important;\\r\\n }\\r\\n .cbmis-margin-7{\\r\\n margin: var(--cbmis-margin-7) !important;\\r\\n }\\r\\n .cbmis-margin-8{\\r\\n margin: var(--cbmis-margin-8) !important;\\r\\n }\\r\\n .cbmis-margin-9{\\r\\n margin: var(--cbmis-margin-9) !important;\\r\\n }\\r\\n .cbmis-margin-10{\\r\\n margin: var(--cbmis-margin-10) !important;\\r\\n }\\r\\n .cbmis-margin-auto{\\r\\n margin: auto !important;\\r\\n }\\r\\n \\r\\n /*margin-top*/\\r\\n .cbmis-margin-top-0{\\r\\n margin-top: var(--cbmis-margin-0) !important;\\r\\n }\\r\\n .cbmis-margin-top-1{\\r\\n margin-top: var(--cbmis-margin-1) !important;\\r\\n }\\r\\n .cbmis-margin-top-2{\\r\\n margin-top: var(--cbmis-margin-2) !important;\\r\\n }\\r\\n .cbmis-margin-top-3{\\r\\n margin-top: var(--cbmis-margin-3) !important;\\r\\n }\\r\\n .cbmis-margin-top-4{\\r\\n margin-top: var(--cbmis-margin-4) !important;\\r\\n }\\r\\n .cbmis-margin-top-5{\\r\\n margin-top: var(--cbmis-margin-5) !important;\\r\\n }\\r\\n .cbmis-margin-top-6{\\r\\n margin-top: var(--cbmis-margin-6) !important;\\r\\n }\\r\\n .cbmis-margin-top-7{\\r\\n margin-top: var(--cbmis-margin-7) !important;\\r\\n }\\r\\n .cbmis-margin-top-8{\\r\\n margin-top: var(--cbmis-margin-8) !important;\\r\\n }\\r\\n .cbmis-margin-top-9{\\r\\n margin-top: var(--cbmis-margin-9) !important;\\r\\n }\\r\\n .cbmis-margin-top-10{\\r\\n margin-top: var(--cbmis-margin-10) !important;\\r\\n }\\r\\n .cbmis-margin-top-auto{\\r\\n margin-top: auto !important;\\r\\n }\\r\\n \\r\\n /*margin-left*/\\r\\n .cbmis-margin-left-0{\\r\\n margin-left: var(--cbmis-margin-0) !important;\\r\\n }\\r\\n .cbmis-margin-left-1{\\r\\n margin-left: var(--cbmis-margin-1) !important;\\r\\n }\\r\\n .cbmis-margin-left-2{\\r\\n margin-left: var(--cbmis-margin-2) !important;\\r\\n }\\r\\n .cbmis-margin-left-3{\\r\\n margin-left: var(--cbmis-margin-3) !important;\\r\\n }\\r\\n .cbmis-margin-left-4{\\r\\n margin-left: var(--cbmis-margin-4) !important;\\r\\n }\\r\\n .cbmis-margin-left-5{\\r\\n margin-left: var(--cbmis-margin-5) !important;\\r\\n }\\r\\n .cbmis-margin-left-6{\\r\\n margin-left: var(--cbmis-margin-6) !important;\\r\\n }\\r\\n .cbmis-margin-left-7{\\r\\n margin-left: var(--cbmis-margin-7) !important;\\r\\n }\\r\\n .cbmis-margin-left-8{\\r\\n margin-left: var(--cbmis-margin-8) !important;\\r\\n }\\r\\n .cbmis-margin-left-9{\\r\\n margin-left: var(--cbmis-margin-9) !important;\\r\\n }\\r\\n .cbmis-margin-left-10{\\r\\n margin-left: var(--cbmis-margin-10) !important;\\r\\n }\\r\\n .cbmis-margin-left-auto{\\r\\n margin-left: auto !important;\\r\\n }\\r\\n \\r\\n /*margin-bottom*/\\r\\n .cbmis-margin-bottom-0{\\r\\n margin-bottom: var(--cbmis-margin-0) !important;\\r\\n }\\r\\n .cbmis-margin-bottom-1{\\r\\n margin-bottom: var(--cbmis-margin-1) !important;\\r\\n }\\r\\n .cbmis-margin-bottom-2{\\r\\n margin-bottom: var(--cbmis-margin-2) !important;\\r\\n }\\r\\n .cbmis-margin-bottom-3{\\r\\n margin-bottom: var(--cbmis-margin-3) !important;\\r\\n }\\r\\n .cbmis-margin-bottom-4{\\r\\n margin-bottom: var(--cbmis-margin-4) !important;\\r\\n }\\r\\n .cbmis-margin-bottom-5{\\r\\n margin-bottom: var(--cbmis-margin-5) !important;\\r\\n }\\r\\n .cbmis-margin-bottom-6{\\r\\n margin-bottom: var(--cbmis-margin-6) !important;\\r\\n }\\r\\n .cbmis-margin-bottom-7{\\r\\n margin-bottom: var(--cbmis-margin-7) !important;\\r\\n }\\r\\n .cbmis-margin-bottom-8{\\r\\n margin-bottom: var(--cbmis-margin-8) !important;\\r\\n }\\r\\n .cbmis-margin-bottom-9{\\r\\n margin-bottom: var(--cbmis-margin-9) !important;\\r\\n }\\r\\n .cbmis-margin-bottom-10{\\r\\n margin-bottom: var(--cbmis-margin-10) !important;\\r\\n }\\r\\n .cbmis-margin-bottom-auto{\\r\\n margin-bottom: auto !important;\\r\\n }\\r\\n \\r\\n /*margin-right*/\\r\\n .cbmis-margin-right-0{\\r\\n margin-right: var(--cbmis-margin-0) !important;\\r\\n }\\r\\n .cbmis-margin-right-1{\\r\\n margin-right: var(--cbmis-margin-1) !important;\\r\\n }\\r\\n .cbmis-margin-right-2{\\r\\n margin-right: var(--cbmis-margin-2) !important;\\r\\n }\\r\\n .cbmis-margin-right-3{\\r\\n margin-right: var(--cbmis-margin-3) !important;\\r\\n }\\r\\n .cbmis-margin-right-4{\\r\\n margin-right: var(--cbmis-margin-4) !important;\\r\\n }\\r\\n .cbmis-margin-right-5{\\r\\n margin-right: var(--cbmis-margin-5) !important;\\r\\n }\\r\\n .cbmis-margin-right-6{\\r\\n margin-right: var(--cbmis-margin-6) !important;\\r\\n }\\r\\n .cbmis-margin-right-7{\\r\\n margin-right: var(--cbmis-margin-7) !important;\\r\\n }\\r\\n .cbmis-margin-right-8{\\r\\n margin-right: var(--cbmis-margin-8) !important;\\r\\n }\\r\\n .cbmis-margin-right-9{\\r\\n margin-right: var(--cbmis-margin-9) !important;\\r\\n }\\r\\n .cbmis-margin-right-10{\\r\\n margin-right: var(--cbmis-margin-10) !important;\\r\\n }\\r\\n .cbmis-margin-right-auto{\\r\\n margin-right: auto !important;\\r\\n }\\r\\n \\r\\n /*margin-y*/\\r\\n .cbmis-margin-y-0{\\r\\n margin-top: var(--cbmis-margin-0) !important;\\r\\n margin-bottom: var(--cbmis-margin-0) !important;\\r\\n }\\r\\n .cbmis-margin-y-1{\\r\\n margin-top: var(--cbmis-margin-1) !important;\\r\\n margin-bottom: var(--cbmis-margin-1) !important;\\r\\n }\\r\\n .cbmis-margin-y-2{\\r\\n margin-top: var(--cbmis-margin-2) !important;\\r\\n margin-bottom: var(--cbmis-margin-2) !important;\\r\\n }\\r\\n .cbmis-margin-y-3{\\r\\n margin-top: var(--cbmis-margin-3) !important;\\r\\n margin-bottom: var(--cbmis-margin-3) !important;\\r\\n }\\r\\n .cbmis-margin-y-4{\\r\\n margin-top: var(--cbmis-margin-4) !important;\\r\\n margin-bottom: var(--cbmis-margin-4) !important;\\r\\n }\\r\\n .cbmis-margin-y-5{\\r\\n margin-top: var(--cbmis-margin-5) !important;\\r\\n margin-bottom: var(--cbmis-margin-5) !important;\\r\\n }\\r\\n .cbmis-margin-y-6{\\r\\n margin-top: var(--cbmis-margin-6) !important;\\r\\n margin-bottom: var(--cbmis-margin-6) !important;\\r\\n }\\r\\n .cbmis-margin-y-7{\\r\\n margin-top: var(--cbmis-margin-7) !important;\\r\\n margin-bottom: var(--cbmis-margin-7) !important;\\r\\n }\\r\\n .cbmis-margin-y-8{\\r\\n margin-top: var(--cbmis-margin-8) !important;\\r\\n margin-bottom: var(--cbmis-margin-8) !important;\\r\\n }\\r\\n .cbmis-margin-y-9{\\r\\n margin-top: var(--cbmis-margin-9) !important;\\r\\n margin-bottom: var(--cbmis-margin-9) !important;\\r\\n }\\r\\n .cbmis-margin-y-10{\\r\\n margin-top: var(--cbmis-margin-10) !important;\\r\\n margin-bottom: var(--cbmis-margin-10) !important;\\r\\n }\\r\\n .cbmis-margin-y-auto{\\r\\n margin-top: auto !important;\\r\\n margin-bottom: auto !important;\\r\\n }\\r\\n \\r\\n /*margin-x*/\\r\\n .cbmis-margin-x-0{\\r\\n margin-left: var(--cbmis-margin-0) !important;\\r\\n margin-bottom: var(--cbmis-margin-0) !important;\\r\\n }\\r\\n .cbmis-margin-x-1{\\r\\n margin-left: var(--cbmis-margin-1) !important;\\r\\n margin-right: var(--cbmis-margin-1) !important;\\r\\n }\\r\\n .cbmis-margin-x-2{\\r\\n margin-left: var(--cbmis-margin-2) !important;\\r\\n margin-right: var(--cbmis-margin-2) !important;\\r\\n }\\r\\n .cbmis-margin-x-3{\\r\\n margin-left: var(--cbmis-margin-3) !important;\\r\\n margin-right: var(--cbmis-margin-3) !important;\\r\\n }\\r\\n .cbmis-margin-x-4{\\r\\n margin-left: var(--cbmis-margin-4) !important;\\r\\n margin-right: var(--cbmis-margin-4) !important;\\r\\n }\\r\\n .cbmis-margin-x-5{\\r\\n margin-left: var(--cbmis-margin-5) !important;\\r\\n margin-right: var(--cbmis-margin-5) !important;\\r\\n }\\r\\n .cbmis-margin-x-6{\\r\\n margin-left: var(--cbmis-margin-6) !important;\\r\\n margin-right: var(--cbmis-margin-6) !important;\\r\\n }\\r\\n .cbmis-margin-x-7{\\r\\n margin-left: var(--cbmis-margin-7) !important;\\r\\n margin-right: var(--cbmis-margin-7) !important;\\r\\n }\\r\\n .cbmis-margin-x-8{\\r\\n margin-left: var(--cbmis-margin-8) !important;\\r\\n margin-right: var(--cbmis-margin-8) !important;\\r\\n }\\r\\n .cbmis-margin-x-9{\\r\\n margin-left: var(--cbmis-margin-9) !important;\\r\\n margin-right: var(--cbmis-margin-9) !important;\\r\\n }\\r\\n .cbmis-margin-x-10{\\r\\n margin-left: var(--cbmis-margin-10) !important;\\r\\n margin-right: var(--cbmis-margin-10) !important;\\r\\n }\\r\\n .cbmis-margin-x-auto{\\r\\n margin-left: auto !important;\\r\\n margin-right: auto !important;\\r\\n }\\r\\n \\r\\n /*padding*/\\r\\n .cbmis-padding-0{\\r\\n padding: var(--cbmis-padding-0) !important;\\r\\n }\\r\\n .cbmis-padding-1{\\r\\n padding: var(--cbmis-padding-1) !important;\\r\\n }\\r\\n .cbmis-padding-2{\\r\\n padding: var(--cbmis-padding-2) !important;\\r\\n }\\r\\n .cbmis-padding-3{\\r\\n padding: var(--cbmis-padding-3) !important;\\r\\n }\\r\\n .cbmis-padding-4{\\r\\n padding: var(--cbmis-padding-4) !important;\\r\\n }\\r\\n .cbmis-padding-5{\\r\\n padding: var(--cbmis-padding-5) !important;\\r\\n }\\r\\n .cbmis-padding-6{\\r\\n padding: var(--cbmis-padding-6) !important;\\r\\n }\\r\\n .cbmis-padding-7{\\r\\n padding: var(--cbmis-padding-7) !important;\\r\\n }\\r\\n .cbmis-padding-8{\\r\\n padding: var(--cbmis-padding-8) !important;\\r\\n }\\r\\n .cbmis-padding-9{\\r\\n padding: var(--cbmis-padding-9) !important;\\r\\n }\\r\\n .cbmis-padding-10{\\r\\n padding: var(--cbmis-padding-10) !important;\\r\\n }\\r\\n .cbmis-padding-auto{\\r\\n padding: auto !important;\\r\\n }\\r\\n \\r\\n /*padding-top*/\\r\\n .cbmis-padding-top-0{\\r\\n padding-top: var(--cbmis-padding-0) !important;\\r\\n }\\r\\n .cbmis-padding-top-1{\\r\\n padding-top: var(--cbmis-padding-1) !important;\\r\\n }\\r\\n .cbmis-padding-top-2{\\r\\n padding-top: var(--cbmis-padding-2) !important;\\r\\n }\\r\\n .cbmis-padding-top-3{\\r\\n padding-top: var(--cbmis-padding-3) !important;\\r\\n }\\r\\n .cbmis-padding-top-4{\\r\\n padding-top: var(--cbmis-padding-4) !important;\\r\\n }\\r\\n .cbmis-padding-top-5{\\r\\n padding-top: var(--cbmis-padding-5) !important;\\r\\n }\\r\\n .cbmis-padding-top-6{\\r\\n padding-top: var(--cbmis-padding-6) !important;\\r\\n }\\r\\n .cbmis-padding-top-7{\\r\\n padding-top: var(--cbmis-padding-7) !important;\\r\\n }\\r\\n .cbmis-padding-top-8{\\r\\n padding-top: var(--cbmis-padding-8) !important;\\r\\n }\\r\\n .cbmis-padding-top-9{\\r\\n padding-top: var(--cbmis-padding-9) !important;\\r\\n }\\r\\n .cbmis-padding-top-10{\\r\\n padding-top: var(--cbmis-padding-10) !important;\\r\\n }\\r\\n .cbmis-padding-top-auto{\\r\\n padding-top: auto !important;\\r\\n }\\r\\n /*padding-left*/\\r\\n .cbmis-padding-left-0{\\r\\n padding-left: var(--cbmis-padding-0) !important;\\r\\n }\\r\\n .cbmis-padding-left-1{\\r\\n padding-left: var(--cbmis-padding-1) !important;\\r\\n }\\r\\n .cbmis-padding-left-2{\\r\\n padding-left: var(--cbmis-padding-2) !important;\\r\\n }\\r\\n .cbmis-padding-left-3{\\r\\n padding-left: var(--cbmis-padding-3) !important;\\r\\n }\\r\\n .cbmis-padding-left-4{\\r\\n padding-left: var(--cbmis-padding-4) !important;\\r\\n }\\r\\n .cbmis-padding-left-5{\\r\\n padding-left: var(--cbmis-padding-5) !important;\\r\\n }\\r\\n .cbmis-padding-left-6{\\r\\n padding-left: var(--cbmis-padding-6) !important;\\r\\n }\\r\\n .cbmis-padding-left-7{\\r\\n padding-left: var(--cbmis-padding-7) !important;\\r\\n }\\r\\n .cbmis-padding-left-8{\\r\\n padding-left: var(--cbmis-padding-8) !important;\\r\\n }\\r\\n .cbmis-padding-left-9{\\r\\n padding-left: var(--cbmis-padding-9) !important;\\r\\n }\\r\\n .cbmis-padding-left-10{\\r\\n padding-left: var(--cbmis-padding-10) !important;\\r\\n }\\r\\n .cbmis-padding-left-auto{\\r\\n padding-left: auto !important;\\r\\n }\\r\\n \\r\\n /*padding-bottom*/\\r\\n .cbmis-padding-bottom-0{\\r\\n padding-bottom: var(--cbmis-padding-0) !important;\\r\\n }\\r\\n .cbmis-padding-bottom-1{\\r\\n padding-bottom: var(--cbmis-padding-1) !important;\\r\\n }\\r\\n .cbmis-padding-bottom-2{\\r\\n padding-bottom: var(--cbmis-padding-2) !important;\\r\\n }\\r\\n .cbmis-padding-bottom-3{\\r\\n padding-bottom: var(--cbmis-padding-3) !important;\\r\\n }\\r\\n .cbmis-padding-bottom-4{\\r\\n padding-bottom: var(--cbmis-padding-4) !important;\\r\\n }\\r\\n .cbmis-padding-bottom-5{\\r\\n padding-bottom: var(--cbmis-padding-5) !important;\\r\\n }\\r\\n .cbmis-padding-bottom-6{\\r\\n padding-bottom: var(--cbmis-padding-6) !important;\\r\\n }\\r\\n .cbmis-padding-bottom-7{\\r\\n padding-bottom: var(--cbmis-padding-7) !important;\\r\\n }\\r\\n .cbmis-padding-bottom-8{\\r\\n padding-bottom: var(--cbmis-padding-8) !important;\\r\\n }\\r\\n .cbmis-padding-bottom-9{\\r\\n padding-bottom: var(--cbmis-padding-9) !important;\\r\\n }\\r\\n .cbmis-padding-bottom-10{\\r\\n padding-bottom: var(--cbmis-padding-10) !important;\\r\\n }\\r\\n .cbmis-padding-bottom-auto{\\r\\n padding-bottom: auto !important;\\r\\n }\\r\\n \\r\\n /*padding-right*/\\r\\n .cbmis-padding-right-0{\\r\\n padding-right: var(--cbmis-padding-0) !important;\\r\\n }\\r\\n .cbmis-padding-right-1{\\r\\n padding-right: var(--cbmis-padding-1) !important;\\r\\n }\\r\\n .cbmis-padding-right-2{\\r\\n padding-right: var(--cbmis-padding-2) !important;\\r\\n }\\r\\n .cbmis-padding-right-3{\\r\\n padding-right: var(--cbmis-padding-3) !important;\\r\\n }\\r\\n .cbmis-padding-right-4{\\r\\n padding-right: var(--cbmis-padding-4) !important;\\r\\n }\\r\\n .cbmis-padding-right-5{\\r\\n padding-right: var(--cbmis-padding-5) !important;\\r\\n }\\r\\n .cbmis-padding-right-6{\\r\\n padding-right: var(--cbmis-padding-6) !important;\\r\\n }\\r\\n .cbmis-padding-right-7{\\r\\n padding-right: var(--cbmis-padding-7) !important;\\r\\n }\\r\\n .cbmis-padding-right-8{\\r\\n padding-right: var(--cbmis-padding-8) !important;\\r\\n }\\r\\n .cbmis-padding-right-9{\\r\\n padding-right: var(--cbmis-padding-9) !important;\\r\\n }\\r\\n .cbmis-padding-right-10{\\r\\n padding-right: var(--cbmis-padding-10) !important;\\r\\n }\\r\\n .cbmis-padding-right-auto{\\r\\n padding-right: auto !important;\\r\\n }\\r\\n \\r\\n /*padding-y*/\\r\\n .cbmis-padding-y-0{\\r\\n padding-top: var(--cbmis-padding-0) !important;\\r\\n padding-bottom: var(--cbmis-padding-0) !important;\\r\\n }\\r\\n .cbmis-padding-y-1{\\r\\n padding-top: var(--cbmis-padding-1) !important;\\r\\n padding-bottom: var(--cbmis-padding-1) !important;\\r\\n }\\r\\n .cbmis-padding-y-2{\\r\\n padding-top: var(--cbmis-padding-2) !important;\\r\\n padding-bottom: var(--cbmis-padding-2) !important;\\r\\n }\\r\\n .cbmis-padding-y-3{\\r\\n padding-top: var(--cbmis-padding-3) !important;\\r\\n padding-bottom: var(--cbmis-padding-3) !important;\\r\\n }\\r\\n .cbmis-padding-y-4{\\r\\n padding-top: var(--cbmis-padding-4) !important;\\r\\n padding-bottom: var(--cbmis-padding-4) !important;\\r\\n }\\r\\n .cbmis-padding-y-5{\\r\\n padding-top: var(--cbmis-padding-5) !important;\\r\\n padding-bottom: var(--cbmis-padding-5) !important;\\r\\n }\\r\\n .cbmis-padding-y-6{\\r\\n padding-top: var(--cbmis-padding-6) !important;\\r\\n padding-bottom: var(--cbmis-padding-6) !important;\\r\\n }\\r\\n .cbmis-padding-y-7{\\r\\n padding-top: var(--cbmis-padding-7) !important;\\r\\n padding-bottom: var(--cbmis-padding-7) !important;\\r\\n }\\r\\n .cbmis-padding-y-8{\\r\\n padding-top: var(--cbmis-padding-8) !important;\\r\\n padding-bottom: var(--cbmis-padding-8) !important;\\r\\n }\\r\\n .cbmis-padding-y-9{\\r\\n padding-top: var(--cbmis-padding-9) !important;\\r\\n padding-bottom: var(--cbmis-padding-9) !important;\\r\\n }\\r\\n .cbmis-padding-y-10{\\r\\n padding-top: var(--cbmis-padding-10) !important;\\r\\n padding-bottom: var(--cbmis-padding-10) !important;\\r\\n }\\r\\n .cbmis-padding-y-auto{\\r\\n padding-top: auto !important;\\r\\n padding-bottom: auto !important;\\r\\n }\\r\\n \\r\\n /*padding-x*/\\r\\n .cbmis-padding-x-0{\\r\\n padding-left: var(--cbmis-padding-0) !important;\\r\\n padding-bottom: var(--cbmis-padding-0) !important;\\r\\n }\\r\\n .cbmis-padding-x-1{\\r\\n padding-left: var(--cbmis-padding-1) !important;\\r\\n padding-right: var(--cbmis-padding-1) !important;\\r\\n }\\r\\n .cbmis-padding-x-2{\\r\\n padding-left: var(--cbmis-padding-2) !important;\\r\\n padding-right: var(--cbmis-padding-2) !important;\\r\\n }\\r\\n .cbmis-padding-x-3{\\r\\n padding-left: var(--cbmis-padding-3) !important;\\r\\n padding-right: var(--cbmis-padding-3) !important;\\r\\n }\\r\\n .cbmis-padding-x-4{\\r\\n padding-left: var(--cbmis-padding-4) !important;\\r\\n padding-right: var(--cbmis-padding-4) !important;\\r\\n }\\r\\n .cbmis-padding-x-5{\\r\\n padding-left: var(--cbmis-padding-5) !important;\\r\\n padding-right: var(--cbmis-padding-5) !important;\\r\\n }\\r\\n .cbmis-padding-x-6{\\r\\n padding-left: var(--cbmis-padding-6) !important;\\r\\n padding-right: var(--cbmis-padding-6) !important;\\r\\n }\\r\\n .cbmis-padding-x-7{\\r\\n padding-left: var(--cbmis-padding-7) !important;\\r\\n padding-right: var(--cbmis-padding-7) !important;\\r\\n }\\r\\n .cbmis-padding-x-8{\\r\\n padding-left: var(--cbmis-padding-8) !important;\\r\\n padding-right: var(--cbmis-padding-8) !important;\\r\\n }\\r\\n .cbmis-padding-x-9{\\r\\n padding-left: var(--cbmis-padding-9) !important;\\r\\n padding-right: var(--cbmis-padding-9) !important;\\r\\n }\\r\\n .cbmis-padding-x-10{\\r\\n padding-left: var(--cbmis-padding-10) !important;\\r\\n padding-right: var(--cbmis-padding-10) !important;\\r\\n }\\r\\n \\r\\n .cbmis-padding-x-auto{\\r\\n padding-left: auto !important;\\r\\n padding-right: auto !important;\\r\\n }\\r\\n \\r\\n\\r\\n /* **************************************** hidden ******************************************* */\\r\\n\\r\\n .cbmis-invisible-hidden ,.cbmis-invisible-hidden>*{\\r\\n visibility: hidden !important;\\r\\n opacity: 0 !important;\\r\\n z-index: var(--cbmis-z-index-0) !important;\\r\\n width: 0 !important;\\r\\n height: 0 !important;\\r\\n padding: 0 !important;\\r\\n margin: 0 !important;\\r\\n border-width: 0 !important;\\r\\n position: fixed !important;\\r\\n top: 0 !important;\\r\\n display: none !important;\\r\\n }\\r\\n\\r\\n /* **************************************** scrollbar ******************************************* */\\r\\n \\r\\n /* width */\\r\\n ::-webkit-scrollbar {\\r\\n width: 10px;\\r\\n }\\r\\n \\r\\n /* Track */\\r\\n ::-webkit-scrollbar-track {\\r\\n background: transparent;\\r\\n border:solid var(--cbmis-secondary-200);\\r\\n border-width: 0 1px;\\r\\n }\\r\\n\\r\\n /* Handle */\\r\\n ::-webkit-scrollbar-thumb {\\r\\n background: var(--cbmis-secondary-500); \\r\\n opacity: .5;\\r\\n }\\r\\n\\r\\n /* Handle on hover */\\r\\n ::-webkit-scrollbar-thumb:hover {\\r\\n background: var(--cbmis-secondary-700);\\r\\n opacity: .5;\\r\\n }\\r\\n\\r\\n @media only screen and (max-width: 576px) {\\r\\n ::-webkit-scrollbar{\\r\\n position: absolute;\\r\\n width: 0 !important;\\r\\n height: 0 !important;\\r\\n opacity: 0 !important;\\r\\n }\\r\\n ::-webkit-scrollbar-track {\\r\\n opacity: 0;\\r\\n visibility: hidden;\\r\\n background: transparent;\\r\\n }\\r\\n ::-webkit-scrollbar-thumb ,::-webkit-scrollbar-thumb:hover{\\r\\n opacity: 0;\\r\\n visibility: hidden;\\r\\n background: transparent;\\r\\n }\\r\\n }\\r\\n\\r\\n .cbmis-border-radius-pill{\\r\\n border-radius: var(--cbmis-border-radius-pill) !important;\\r\\n }\"],\"sourceRoot\":\"\"}]);\n// Exports\nexport default ___CSS_LOADER_EXPORT___;\n","// Imports\nimport ___CSS_LOADER_API_SOURCEMAP_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/sourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/api.js\";\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_SOURCEMAP_IMPORT___);\n___CSS_LOADER_EXPORT___.push([module.id, \"@import url(https://fonts.googleapis.com/css2?family=Baloo+Bhaijaan+2:wght@400..800&family=Reem+Kufi:wght@400..700&display=swap);\"]);\n___CSS_LOADER_EXPORT___.push([module.id, \"@import url(https://fonts.googleapis.com/css2?family=Baloo+Bhaijaan+2:wght@400..800&family=Harmattan:wght@400;500;600;700&family=Reem+Kufi:wght@400..700&display=swap);\"]);\n___CSS_LOADER_EXPORT___.push([module.id, \"@import url(https://fonts.googleapis.com/css2?family=Baloo+Bhaijaan+2:wght@400..800&family=Harmattan:wght@400;500;600;700&family=Lemonada:wght@300..700&family=Reem+Kufi:wght@400..700&display=swap);\"]);\n___CSS_LOADER_EXPORT___.push([module.id, \"@import url(https://fonts.googleapis.com/css2?family=Baloo+Bhaijaan+2:wght@400..800&family=Harmattan:wght@400;500;600;700&family=Lemonada:wght@300..700&family=Noto+Nastaliq+Urdu:wght@400..700&family=Reem+Kufi:wght@400..700&display=swap);\"]);\n___CSS_LOADER_EXPORT___.push([module.id, \"@import url(https://fonts.googleapis.com/css2?family=Abel&family=Alexandria:wght@300&family=Almarai:wght@300;400&family=Amiri&family=Amiri+Quran&family=Anton&family=Anuphan:wght@300&family=Aref+Ruqaa&family=Aref+Ruqaa+Ink&family=Baloo+Bhaijaan+2&family=Barlow+Semi+Condensed:wght@300;400;500&family=Bebas+Neue&family=Bitter:wght@300&family=Blaka&family=Blaka+Hollow&family=Blaka+Ink&family=Bruno+Ace&family=Bruno+Ace+SC&family=Cabin&family=Cairo+Play:wght@300&family=Cairo:wght@300&family=Cardo:wght@400;700&family=Carlito&family=Caveat:wght@400;500;600&family=Chakra+Petch:wght@300;400&family=Changa:wght@300&family=Chivo+Mono:wght@300&family=Comfortaa:wght@300&family=Cormorant:wght@300;400&family=Courgette&family=Crimson+Text&family=Dancing+Script:wght@400;500;600&family=EB+Garamond&family=El+Messiri&family=Exo+2:wght@300&family=Figtree:wght@300;400&family=Fira+Sans:wght@300&family=Fjalla+One&family=Great+Vibes&family=Harmattan&family=IBM+Plex+Mono:wght@300;400&family=IBM+Plex+Sans+Arabic:wght@300;500&family=Imbue:wght@300;400&family=Indie+Flower&family=Instrument+Serif&family=Jomhuria&family=Josefin+Sans:wght@300&family=Kalam:wght@300;400&family=Katibeh&family=Kufam&family=Lalezar&family=Lateef:wght@300&family=Lato:wght@300&family=Lemonada:wght@300&family=Libre+Baskerville&family=Lilita+One&family=Lobster&family=Lobster+Two:ital@0;1&family=Mada:wght@300&family=Marhey:wght@300&family=Markazi+Text&family=Merriweather:wght@300&family=Mirza&family=Montserrat+Alternates:wght@300;400&family=Montserrat:wght@300&family=Noticia+Text&family=Noto+Kufi+Arabic:wght@300&family=Noto+Naskh+Arabic:wght@400;500&family=Noto+Nastaliq+Urdu&family=Noto+Sans+Arabic:wght@300&family=Noto+Serif&family=Oswald:wght@300&family=Oxygen:wght@300&family=Pacifico&family=Patua+One&family=Permanent+Marker&family=Playfair+Display&family=Poppins:wght@300&family=Prompt:wght@300&family=Qahiri&family=Questrial&family=Quicksand:wght@300&family=Raleway:wght@300&family=Readex+Pro:wght@300&family=Reem+Kufi&family=Reem+Kufi+Fun&family=Reem+Kufi+Ink&family=Righteous&family=Roboto+Mono:wght@300&family=Roboto+Slab:wght@300&family=Roboto:wght@300;400&family=Satisfy&family=Scheherazade+New&family=Schibsted+Grotesk&family=Sedgwick+Ave+Display&family=Sigmar&family=Signika+Negative:wght@300&family=Source+Code+Pro:wght@300;400&family=Space+Mono&family=Tajawal:wght@300&family=Teko:wght@300&family=Ubuntu:wght@300&family=Vibes&family=Vina+Sans&family=Yanone+Kaffeesatz:wght@300;400&family=Yellowtail&family=Ysabeau:wght@300&display=swap);\"]);\n___CSS_LOADER_EXPORT___.push([module.id, \"@import url(https://fonts.googleapis.com/css2?family=Abel&family=Alexandria:wght@300&family=Almarai:wght@300;400&family=Amiri&family=Amiri+Quran&family=Anton&family=Anuphan:wght@300&family=Aref+Ruqaa&family=Aref+Ruqaa+Ink&family=Baloo+Bhaijaan+2&family=Barlow+Semi+Condensed:wght@300;400;500&family=Bebas+Neue&family=Bitter:wght@300&family=Blaka&family=Blaka+Hollow&family=Blaka+Ink&family=Bruno+Ace&family=Bruno+Ace+SC&family=Cabin&family=Cairo+Play:wght@300&family=Cairo:wght@300&family=Cardo:wght@400;700&family=Carlito&family=Caveat:wght@400;500;600&family=Chakra+Petch:wght@300;400&family=Changa:wght@300&family=Chivo+Mono:wght@300&family=Comfortaa:wght@300&family=Cormorant:wght@300;400&family=Courgette&family=Crimson+Text&family=Dancing+Script:wght@400;500;600&family=EB+Garamond&family=El+Messiri&family=Exo+2:wght@300&family=Figtree:wght@300;400&family=Fira+Sans:wght@300&family=Fjalla+One&family=Great+Vibes&family=Harmattan&family=IBM+Plex+Mono:wght@300;400&family=IBM+Plex+Sans+Arabic:wght@300;500&family=Imbue:wght@300;400&family=Indie+Flower&family=Instrument+Serif&family=Jomhuria&family=Josefin+Sans:wght@300&family=Kalam:wght@300;400&family=Katibeh&family=Kufam&family=Lalezar&family=Lateef:wght@300&family=Lato:wght@300&family=Lemonada:wght@300&family=Libre+Baskerville&family=Lilita+One&family=Lobster&family=Lobster+Two:ital@0;1&family=Mada:wght@300&family=Marhey:wght@300&family=Markazi+Text&family=Merriweather:wght@300&family=Mirza&family=Montserrat+Alternates:wght@300;400&family=Montserrat:wght@300&family=Noticia+Text&family=Noto+Kufi+Arabic:wght@300&family=Noto+Naskh+Arabic:wght@400;500&family=Noto+Nastaliq+Urdu&family=Noto+Sans+Arabic:wght@300&family=Noto+Serif&family=Oswald:wght@300&family=Oxygen:wght@300&family=Pacifico&family=Patua+One&family=Permanent+Marker&family=Playfair+Display&family=Poppins:wght@300&family=Prompt:wght@300&family=Qahiri&family=Questrial&family=Quicksand:wght@300&family=Raleway:wght@300;400;500&family=Readex+Pro:wght@300&family=Reem+Kufi&family=Reem+Kufi+Fun&family=Reem+Kufi+Ink&family=Righteous&family=Roboto+Mono:wght@300&family=Roboto+Slab:wght@300&family=Roboto:wght@300;400&family=Satisfy&family=Scheherazade+New&family=Schibsted+Grotesk&family=Sedgwick+Ave+Display&family=Sigmar&family=Signika+Negative:wght@300&family=Source+Code+Pro:wght@300;400&family=Space+Mono&family=Tajawal:wght@300&family=Teko:wght@300&family=Ubuntu:wght@300&family=Vibes&family=Vina+Sans&family=Yanone+Kaffeesatz:wght@300;400&family=Yellowtail&family=Ysabeau:wght@300&display=swap);\"]);\n___CSS_LOADER_EXPORT___.push([module.id, \"@import url(https://fonts.googleapis.com/css2?family=Abel&family=Alexandria:wght@300&family=Almarai:wght@300;400&family=Amiri&family=Amiri+Quran&family=Anton&family=Anuphan:wght@300&family=Aref+Ruqaa&family=Aref+Ruqaa+Ink&family=Baloo+Bhaijaan+2&family=Barlow+Semi+Condensed:wght@300;400;500&family=Bebas+Neue&family=Bitter:wght@300&family=Blaka&family=Blaka+Hollow&family=Blaka+Ink&family=Bruno+Ace&family=Bruno+Ace+SC&family=Cabin&family=Cairo+Play:wght@300&family=Cairo:wght@300&family=Cardo:wght@400;700&family=Carlito&family=Caveat:wght@400;500;600&family=Chakra+Petch:wght@300;400&family=Changa:wght@300&family=Chivo+Mono:wght@300&family=Comfortaa:wght@300&family=Cormorant:wght@300;400&family=Courgette&family=Crimson+Text&family=Dancing+Script:wght@400;500;600&family=EB+Garamond&family=El+Messiri&family=Exo+2:wght@300&family=Figtree:wght@300;400&family=Fira+Sans:wght@300&family=Fjalla+One&family=Great+Vibes&family=Harmattan&family=IBM+Plex+Mono:wght@300;400&family=IBM+Plex+Sans+Arabic:wght@300;500&family=Imbue:wght@300;400&family=Indie+Flower&family=Instrument+Serif&family=Jomhuria&family=Josefin+Sans:wght@300&family=Kalam:wght@300;400&family=Katibeh&family=Kufam&family=Lalezar&family=Lateef:wght@300&family=Lato:wght@300&family=Lemonada:wght@300&family=Libre+Baskerville&family=Lilita+One&family=Lobster&family=Lobster+Two:ital@0;1&family=Mada:wght@300&family=Marhey:wght@300&family=Markazi+Text&family=Merriweather:wght@300&family=Mirza&family=Montserrat+Alternates:wght@300;400&family=Montserrat:wght@300&family=Noticia+Text&family=Noto+Kufi+Arabic:wght@300&family=Noto+Naskh+Arabic:wght@400;500&family=Noto+Nastaliq+Urdu&family=Noto+Sans+Arabic:wght@300&family=Noto+Serif&family=Oswald:wght@300&family=Oxygen:wght@300&family=Pacifico&family=Patua+One&family=Permanent+Marker&family=Playfair+Display&family=Poppins:wght@300&family=Prompt:wght@300&family=Qahiri&family=Questrial&family=Quicksand:wght@300&family=Raleway:wght@300;400;500&family=Readex+Pro:wght@300&family=Reem+Kufi&family=Reem+Kufi+Fun&family=Reem+Kufi+Ink&family=Righteous&family=Roboto+Mono:wght@300&family=Roboto+Slab:wght@300&family=Roboto:wght@300;400&family=Satisfy&family=Scheherazade+New&family=Schibsted+Grotesk&family=Sedgwick+Ave+Display&family=Sigmar&family=Signika+Negative:wght@300&family=Source+Code+Pro:wght@300;400&family=Space+Mono&family=Tajawal:wght@300&family=Teko:wght@300&family=Ubuntu:wght@300&family=Vibes&family=Vina+Sans&family=Yanone+Kaffeesatz:wght@300;400&family=Yellowtail&family=Ysabeau:wght@300&display=swap);\"]);\n___CSS_LOADER_EXPORT___.push([module.id, \"@import url(https://fonts.googleapis.com/css2?family=Baloo+Bhaijaan+2:wght@400..800&family=Harmattan:wght@400;500;600;700&family=Lemonada:wght@300..700&family=Noto+Nastaliq+Urdu:wght@400..700&family=Recursive:wght@300..1000&family=Reem+Kufi:wght@400..700&display=swap);\"]);\n___CSS_LOADER_EXPORT___.push([module.id, \"@import url(https://fonts.googleapis.com/css2?family=Baloo+Bhaijaan+2:wght@400..800&family=Gaegu&family=Harmattan:wght@400;500;600;700&family=Lemonada:wght@300..700&family=Noto+Nastaliq+Urdu:wght@400..700&family=Recursive:wght@300..1000&family=Reem+Kufi:wght@400..700&display=swap);\"]);\n___CSS_LOADER_EXPORT___.push([module.id, \"@import url(https://fonts.googleapis.com/css2?family=Baloo+Bhaijaan+2:wght@400..800&family=El+Messiri:wght@400..700&family=Gaegu&family=Harmattan:wght@400;500;600;700&family=Lemonada:wght@300..700&family=Noto+Nastaliq+Urdu:wght@400..700&family=Recursive:wght@300..1000&family=Reem+Kufi:wght@400..700&display=swap);\"]);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, \".client_body_back *{\\r\\n /* z-index: unset !important; */\\r\\n}\\r\\n\\r\\n.client_disabled{\\r\\n pointer-events:none !important;\\r\\n cursor: not-allowed !important;\\r\\n color:#aaa !important;\\r\\n /* position: relative; */\\r\\n}\\r\\n.client_disabled *{\\r\\n color:currentColor !important;\\r\\n /* position: relative; */\\r\\n}\\r\\n/* .client_disabled label,.client_disabled a, .client_disabled div, .client_disabled p{\\r\\n pointer-events:none !important;\\r\\n cursor: not-allowed !important;\\r\\n color:#aaa !important;\\r\\n}\\r\\n.client_disabled::after{\\r\\n content:\\\"\\\" ;\\r\\n position: absolute !important;\\r\\n top: 1% !important;\\r\\n left: 0 !important;\\r\\n width: 100% !important;\\r\\n height: 98% !important;\\r\\n z-index: 10;\\r\\n pointer-events:none !important;\\r\\n cursor: not-allowed !important;\\r\\n background: #ced1d567 !important;\\r\\n color:#aaa !important;\\r\\n border-radius: 8px;\\r\\n -webkit-border-radius: 8px;\\r\\n -moz-border-radius: 8px;\\r\\n -ms-border-radius: 8px;\\r\\n -o-border-radius: 8px;\\r\\n} */\\r\\n.client_invisible_hidden ,.client_invisible_hidden>*{\\r\\n visibility: hidden !important;\\r\\n opacity: 0 !important;\\r\\n z-index: 0 !important;\\r\\n width: 0 !important;\\r\\n height: 0 !important;\\r\\n padding: 0 !important;\\r\\n margin: 0 !important;\\r\\n border-width: 0 !important;\\r\\n position: fixed !important;\\r\\n top: 0 !important;\\r\\n display: none !important;\\r\\n}\\r\\n\\r\\n.client_dir_ltr{\\r\\n direction: ltr !important;\\r\\n}\\r\\n.client_dir_rtl{\\r\\n direction: rtl !important;\\r\\n}\\r\\n\\r\\n/* input */\\r\\ninput[type=\\\"date\\\"]::-webkit-calendar-picker-indicator, input[type=\\\"time\\\"]::-webkit-calendar-picker-indicator, input[type=\\\"datetime-local\\\"]::-webkit-calendar-picker-indicator {\\r\\n position: absolute !important;\\r\\n width: 100% !important;\\r\\n opacity: 0 !important;\\r\\n }\\r\\n /* **************************************** scrollbar ******************************************* */\\r\\n \\r\\n /* width */\\r\\n ::-webkit-scrollbar {\\r\\n width: 9px;\\r\\n }\\r\\n \\r\\n /* Track */\\r\\n ::-webkit-scrollbar-track {\\r\\n background: transparent;\\r\\n border:solid #e5e7eb;\\r\\n border-width: 0 1px;\\r\\n }\\r\\n\\r\\n /* Handle */\\r\\n ::-webkit-scrollbar-thumb {\\r\\n background: #c0c0c0;\\r\\n opacity: .3;\\r\\n border-radius:1px;\\r\\n -webkit-border-radius:1px;\\r\\n -moz-border-radius:1px;\\r\\n -ms-border-radius:1px;\\r\\n -o-border-radius:1px;\\r\\n}\\r\\n\\r\\n /* Handle on hover */\\r\\n ::-webkit-scrollbar-thumb:hover {\\r\\n background: #aaa;\\r\\n opacity: .8;\\r\\n border-radius: 0.8rem;\\r\\n -webkit-border-radius: 0.8rem;\\r\\n -moz-border-radius: 0.8rem;\\r\\n -ms-border-radius: 0.8rem;\\r\\n -o-border-radius: 0.8rem;\\r\\n}\\r\\n\\r\\n @media only screen and (max-width: 576px) {\\r\\n ::-webkit-scrollbar{\\r\\n position: absolute;\\r\\n width: 0 !important;\\r\\n height: 0 !important;\\r\\n opacity: 0 !important;\\r\\n }\\r\\n ::-webkit-scrollbar-track {\\r\\n opacity: 0;\\r\\n visibility: hidden;\\r\\n background: transparent;\\r\\n }\\r\\n ::-webkit-scrollbar-thumb ,::-webkit-scrollbar-thumb:hover{\\r\\n opacity: 0;\\r\\n visibility: hidden;\\r\\n background: transparent;\\r\\n }\\r\\n }\", \"\",{\"version\":3,\"sources\":[\"webpack://./style/src/style/themes.css\"],\"names\":[],\"mappings\":\"AAYA;EACE,+BAA+B;AACjC;;AAEA;EACE,8BAA8B;EAC9B,8BAA8B;EAC9B,qBAAqB;EACrB,wBAAwB;AAC1B;AACA;EACE,6BAA6B;EAC7B,wBAAwB;AAC1B;AACA;;;;;;;;;;;;;;;;;;;;;;GAsBG;AACH;EACE,6BAA6B;EAC7B,qBAAqB;EACrB,qBAAqB;EACrB,mBAAmB;EACnB,oBAAoB;EACpB,qBAAqB;EACrB,oBAAoB;EACpB,0BAA0B;EAC1B,0BAA0B;EAC1B,iBAAiB;EACjB,wBAAwB;AAC1B;;AAEA;EACE,yBAAyB;AAC3B;AACA;EACE,yBAAyB;AAC3B;;AAEA,UAAU;AACV;EACE,6BAA6B;EAC7B,sBAAsB;EACtB,qBAAqB;CACtB;EACC,mGAAmG;;EAEnG,UAAU;EACV;IACE,UAAU;EACZ;;EAEA,UAAU;EACV;IACE,uBAAuB;IACvB,oBAAoB;IACpB,mBAAmB;EACrB;;EAEA,WAAW;EACX;IACE,mBAAmB;IACnB,WAAW;IACX,iBAAiB;IACjB,yBAAyB;IACzB,sBAAsB;IACtB,qBAAqB;IACrB,oBAAoB;AACxB;;EAEE,oBAAoB;EACpB;IACE,gBAAgB;IAChB,WAAW;IACX,qBAAqB;IACrB,6BAA6B;IAC7B,0BAA0B;IAC1B,yBAAyB;IACzB,wBAAwB;AAC5B;;EAEE;IACE;MACE,kBAAkB;MAClB,mBAAmB;MACnB,oBAAoB;MACpB,qBAAqB;IACvB;IACA;MACE,UAAU;MACV,kBAAkB;MAClB,uBAAuB;IACzB;IACA;MACE,UAAU;MACV,kBAAkB;MAClB,uBAAuB;IACzB;EACF\",\"sourcesContent\":[\"@import url('https://fonts.googleapis.com/css2?family=Baloo+Bhaijaan+2:wght@400..800&family=Reem+Kufi:wght@400..700&display=swap');\\r\\n@import url('https://fonts.googleapis.com/css2?family=Baloo+Bhaijaan+2:wght@400..800&family=Harmattan:wght@400;500;600;700&family=Reem+Kufi:wght@400..700&display=swap');\\r\\n@import url('https://fonts.googleapis.com/css2?family=Baloo+Bhaijaan+2:wght@400..800&family=Harmattan:wght@400;500;600;700&family=Lemonada:wght@300..700&family=Reem+Kufi:wght@400..700&display=swap');\\r\\n@import url('https://fonts.googleapis.com/css2?family=Baloo+Bhaijaan+2:wght@400..800&family=Harmattan:wght@400;500;600;700&family=Lemonada:wght@300..700&family=Noto+Nastaliq+Urdu:wght@400..700&family=Reem+Kufi:wght@400..700&display=swap');\\r\\n@import url('https://fonts.googleapis.com/css2?family=Abel&family=Alexandria:wght@300&family=Almarai:wght@300;400&family=Amiri&family=Amiri+Quran&family=Anton&family=Anuphan:wght@300&family=Aref+Ruqaa&family=Aref+Ruqaa+Ink&family=Baloo+Bhaijaan+2&family=Barlow+Semi+Condensed:wght@300;400;500&family=Bebas+Neue&family=Bitter:wght@300&family=Blaka&family=Blaka+Hollow&family=Blaka+Ink&family=Bruno+Ace&family=Bruno+Ace+SC&family=Cabin&family=Cairo+Play:wght@300&family=Cairo:wght@300&family=Cardo:wght@400;700&family=Carlito&family=Caveat:wght@400;500;600&family=Chakra+Petch:wght@300;400&family=Changa:wght@300&family=Chivo+Mono:wght@300&family=Comfortaa:wght@300&family=Cormorant:wght@300;400&family=Courgette&family=Crimson+Text&family=Dancing+Script:wght@400;500;600&family=EB+Garamond&family=El+Messiri&family=Exo+2:wght@300&family=Figtree:wght@300;400&family=Fira+Sans:wght@300&family=Fjalla+One&family=Great+Vibes&family=Harmattan&family=IBM+Plex+Mono:wght@300;400&family=IBM+Plex+Sans+Arabic:wght@300;500&family=Imbue:wght@300;400&family=Indie+Flower&family=Instrument+Serif&family=Jomhuria&family=Josefin+Sans:wght@300&family=Kalam:wght@300;400&family=Katibeh&family=Kufam&family=Lalezar&family=Lateef:wght@300&family=Lato:wght@300&family=Lemonada:wght@300&family=Libre+Baskerville&family=Lilita+One&family=Lobster&family=Lobster+Two:ital@0;1&family=Mada:wght@300&family=Marhey:wght@300&family=Markazi+Text&family=Merriweather:wght@300&family=Mirza&family=Montserrat+Alternates:wght@300;400&family=Montserrat:wght@300&family=Noticia+Text&family=Noto+Kufi+Arabic:wght@300&family=Noto+Naskh+Arabic:wght@400;500&family=Noto+Nastaliq+Urdu&family=Noto+Sans+Arabic:wght@300&family=Noto+Serif&family=Oswald:wght@300&family=Oxygen:wght@300&family=Pacifico&family=Patua+One&family=Permanent+Marker&family=Playfair+Display&family=Poppins:wght@300&family=Prompt:wght@300&family=Qahiri&family=Questrial&family=Quicksand:wght@300&family=Raleway:wght@300&family=Readex+Pro:wght@300&family=Reem+Kufi&family=Reem+Kufi+Fun&family=Reem+Kufi+Ink&family=Righteous&family=Roboto+Mono:wght@300&family=Roboto+Slab:wght@300&family=Roboto:wght@300;400&family=Satisfy&family=Scheherazade+New&family=Schibsted+Grotesk&family=Sedgwick+Ave+Display&family=Sigmar&family=Signika+Negative:wght@300&family=Source+Code+Pro:wght@300;400&family=Space+Mono&family=Tajawal:wght@300&family=Teko:wght@300&family=Ubuntu:wght@300&family=Vibes&family=Vina+Sans&family=Yanone+Kaffeesatz:wght@300;400&family=Yellowtail&family=Ysabeau:wght@300&display=swap');\\r\\n@import url('https://fonts.googleapis.com/css2?family=Abel&family=Alexandria:wght@300&family=Almarai:wght@300;400&family=Amiri&family=Amiri+Quran&family=Anton&family=Anuphan:wght@300&family=Aref+Ruqaa&family=Aref+Ruqaa+Ink&family=Baloo+Bhaijaan+2&family=Barlow+Semi+Condensed:wght@300;400;500&family=Bebas+Neue&family=Bitter:wght@300&family=Blaka&family=Blaka+Hollow&family=Blaka+Ink&family=Bruno+Ace&family=Bruno+Ace+SC&family=Cabin&family=Cairo+Play:wght@300&family=Cairo:wght@300&family=Cardo:wght@400;700&family=Carlito&family=Caveat:wght@400;500;600&family=Chakra+Petch:wght@300;400&family=Changa:wght@300&family=Chivo+Mono:wght@300&family=Comfortaa:wght@300&family=Cormorant:wght@300;400&family=Courgette&family=Crimson+Text&family=Dancing+Script:wght@400;500;600&family=EB+Garamond&family=El+Messiri&family=Exo+2:wght@300&family=Figtree:wght@300;400&family=Fira+Sans:wght@300&family=Fjalla+One&family=Great+Vibes&family=Harmattan&family=IBM+Plex+Mono:wght@300;400&family=IBM+Plex+Sans+Arabic:wght@300;500&family=Imbue:wght@300;400&family=Indie+Flower&family=Instrument+Serif&family=Jomhuria&family=Josefin+Sans:wght@300&family=Kalam:wght@300;400&family=Katibeh&family=Kufam&family=Lalezar&family=Lateef:wght@300&family=Lato:wght@300&family=Lemonada:wght@300&family=Libre+Baskerville&family=Lilita+One&family=Lobster&family=Lobster+Two:ital@0;1&family=Mada:wght@300&family=Marhey:wght@300&family=Markazi+Text&family=Merriweather:wght@300&family=Mirza&family=Montserrat+Alternates:wght@300;400&family=Montserrat:wght@300&family=Noticia+Text&family=Noto+Kufi+Arabic:wght@300&family=Noto+Naskh+Arabic:wght@400;500&family=Noto+Nastaliq+Urdu&family=Noto+Sans+Arabic:wght@300&family=Noto+Serif&family=Oswald:wght@300&family=Oxygen:wght@300&family=Pacifico&family=Patua+One&family=Permanent+Marker&family=Playfair+Display&family=Poppins:wght@300&family=Prompt:wght@300&family=Qahiri&family=Questrial&family=Quicksand:wght@300&family=Raleway:wght@300;400;500&family=Readex+Pro:wght@300&family=Reem+Kufi&family=Reem+Kufi+Fun&family=Reem+Kufi+Ink&family=Righteous&family=Roboto+Mono:wght@300&family=Roboto+Slab:wght@300&family=Roboto:wght@300;400&family=Satisfy&family=Scheherazade+New&family=Schibsted+Grotesk&family=Sedgwick+Ave+Display&family=Sigmar&family=Signika+Negative:wght@300&family=Source+Code+Pro:wght@300;400&family=Space+Mono&family=Tajawal:wght@300&family=Teko:wght@300&family=Ubuntu:wght@300&family=Vibes&family=Vina+Sans&family=Yanone+Kaffeesatz:wght@300;400&family=Yellowtail&family=Ysabeau:wght@300&display=swap');\\r\\n@import url('https://fonts.googleapis.com/css2?family=Abel&family=Alexandria:wght@300&family=Almarai:wght@300;400&family=Amiri&family=Amiri+Quran&family=Anton&family=Anuphan:wght@300&family=Aref+Ruqaa&family=Aref+Ruqaa+Ink&family=Baloo+Bhaijaan+2&family=Barlow+Semi+Condensed:wght@300;400;500&family=Bebas+Neue&family=Bitter:wght@300&family=Blaka&family=Blaka+Hollow&family=Blaka+Ink&family=Bruno+Ace&family=Bruno+Ace+SC&family=Cabin&family=Cairo+Play:wght@300&family=Cairo:wght@300&family=Cardo:wght@400;700&family=Carlito&family=Caveat:wght@400;500;600&family=Chakra+Petch:wght@300;400&family=Changa:wght@300&family=Chivo+Mono:wght@300&family=Comfortaa:wght@300&family=Cormorant:wght@300;400&family=Courgette&family=Crimson+Text&family=Dancing+Script:wght@400;500;600&family=EB+Garamond&family=El+Messiri&family=Exo+2:wght@300&family=Figtree:wght@300;400&family=Fira+Sans:wght@300&family=Fjalla+One&family=Great+Vibes&family=Harmattan&family=IBM+Plex+Mono:wght@300;400&family=IBM+Plex+Sans+Arabic:wght@300;500&family=Imbue:wght@300;400&family=Indie+Flower&family=Instrument+Serif&family=Jomhuria&family=Josefin+Sans:wght@300&family=Kalam:wght@300;400&family=Katibeh&family=Kufam&family=Lalezar&family=Lateef:wght@300&family=Lato:wght@300&family=Lemonada:wght@300&family=Libre+Baskerville&family=Lilita+One&family=Lobster&family=Lobster+Two:ital@0;1&family=Mada:wght@300&family=Marhey:wght@300&family=Markazi+Text&family=Merriweather:wght@300&family=Mirza&family=Montserrat+Alternates:wght@300;400&family=Montserrat:wght@300&family=Noticia+Text&family=Noto+Kufi+Arabic:wght@300&family=Noto+Naskh+Arabic:wght@400;500&family=Noto+Nastaliq+Urdu&family=Noto+Sans+Arabic:wght@300&family=Noto+Serif&family=Oswald:wght@300&family=Oxygen:wght@300&family=Pacifico&family=Patua+One&family=Permanent+Marker&family=Playfair+Display&family=Poppins:wght@300&family=Prompt:wght@300&family=Qahiri&family=Questrial&family=Quicksand:wght@300&family=Raleway:wght@300;400;500&family=Readex+Pro:wght@300&family=Reem+Kufi&family=Reem+Kufi+Fun&family=Reem+Kufi+Ink&family=Righteous&family=Roboto+Mono:wght@300&family=Roboto+Slab:wght@300&family=Roboto:wght@300;400&family=Satisfy&family=Scheherazade+New&family=Schibsted+Grotesk&family=Sedgwick+Ave+Display&family=Sigmar&family=Signika+Negative:wght@300&family=Source+Code+Pro:wght@300;400&family=Space+Mono&family=Tajawal:wght@300&family=Teko:wght@300&family=Ubuntu:wght@300&family=Vibes&family=Vina+Sans&family=Yanone+Kaffeesatz:wght@300;400&family=Yellowtail&family=Ysabeau:wght@300&display=swap');\\r\\n@import url('https://fonts.googleapis.com/css2?family=Baloo+Bhaijaan+2:wght@400..800&family=Harmattan:wght@400;500;600;700&family=Lemonada:wght@300..700&family=Noto+Nastaliq+Urdu:wght@400..700&family=Recursive:wght@300..1000&family=Reem+Kufi:wght@400..700&display=swap');\\r\\n@import url('https://fonts.googleapis.com/css2?family=Baloo+Bhaijaan+2:wght@400..800&family=Gaegu&family=Harmattan:wght@400;500;600;700&family=Lemonada:wght@300..700&family=Noto+Nastaliq+Urdu:wght@400..700&family=Recursive:wght@300..1000&family=Reem+Kufi:wght@400..700&display=swap');\\r\\n@import url('https://fonts.googleapis.com/css2?family=Baloo+Bhaijaan+2:wght@400..800&family=El+Messiri:wght@400..700&family=Gaegu&family=Harmattan:wght@400;500;600;700&family=Lemonada:wght@300..700&family=Noto+Nastaliq+Urdu:wght@400..700&family=Recursive:wght@300..1000&family=Reem+Kufi:wght@400..700&display=swap');\\r\\n\\r\\n\\r\\n.client_body_back *{\\r\\n /* z-index: unset !important; */\\r\\n}\\r\\n\\r\\n.client_disabled{\\r\\n pointer-events:none !important;\\r\\n cursor: not-allowed !important;\\r\\n color:#aaa !important;\\r\\n /* position: relative; */\\r\\n}\\r\\n.client_disabled *{\\r\\n color:currentColor !important;\\r\\n /* position: relative; */\\r\\n}\\r\\n/* .client_disabled label,.client_disabled a, .client_disabled div, .client_disabled p{\\r\\n pointer-events:none !important;\\r\\n cursor: not-allowed !important;\\r\\n color:#aaa !important;\\r\\n}\\r\\n.client_disabled::after{\\r\\n content:\\\"\\\" ;\\r\\n position: absolute !important;\\r\\n top: 1% !important;\\r\\n left: 0 !important;\\r\\n width: 100% !important;\\r\\n height: 98% !important;\\r\\n z-index: 10;\\r\\n pointer-events:none !important;\\r\\n cursor: not-allowed !important;\\r\\n background: #ced1d567 !important;\\r\\n color:#aaa !important;\\r\\n border-radius: 8px;\\r\\n -webkit-border-radius: 8px;\\r\\n -moz-border-radius: 8px;\\r\\n -ms-border-radius: 8px;\\r\\n -o-border-radius: 8px;\\r\\n} */\\r\\n.client_invisible_hidden ,.client_invisible_hidden>*{\\r\\n visibility: hidden !important;\\r\\n opacity: 0 !important;\\r\\n z-index: 0 !important;\\r\\n width: 0 !important;\\r\\n height: 0 !important;\\r\\n padding: 0 !important;\\r\\n margin: 0 !important;\\r\\n border-width: 0 !important;\\r\\n position: fixed !important;\\r\\n top: 0 !important;\\r\\n display: none !important;\\r\\n}\\r\\n\\r\\n.client_dir_ltr{\\r\\n direction: ltr !important;\\r\\n}\\r\\n.client_dir_rtl{\\r\\n direction: rtl !important;\\r\\n}\\r\\n\\r\\n/* input */\\r\\ninput[type=\\\"date\\\"]::-webkit-calendar-picker-indicator, input[type=\\\"time\\\"]::-webkit-calendar-picker-indicator, input[type=\\\"datetime-local\\\"]::-webkit-calendar-picker-indicator {\\r\\n position: absolute !important;\\r\\n width: 100% !important;\\r\\n opacity: 0 !important;\\r\\n }\\r\\n /* **************************************** scrollbar ******************************************* */\\r\\n \\r\\n /* width */\\r\\n ::-webkit-scrollbar {\\r\\n width: 9px;\\r\\n }\\r\\n \\r\\n /* Track */\\r\\n ::-webkit-scrollbar-track {\\r\\n background: transparent;\\r\\n border:solid #e5e7eb;\\r\\n border-width: 0 1px;\\r\\n }\\r\\n\\r\\n /* Handle */\\r\\n ::-webkit-scrollbar-thumb {\\r\\n background: #c0c0c0;\\r\\n opacity: .3;\\r\\n border-radius:1px;\\r\\n -webkit-border-radius:1px;\\r\\n -moz-border-radius:1px;\\r\\n -ms-border-radius:1px;\\r\\n -o-border-radius:1px;\\r\\n}\\r\\n\\r\\n /* Handle on hover */\\r\\n ::-webkit-scrollbar-thumb:hover {\\r\\n background: #aaa;\\r\\n opacity: .8;\\r\\n border-radius: 0.8rem;\\r\\n -webkit-border-radius: 0.8rem;\\r\\n -moz-border-radius: 0.8rem;\\r\\n -ms-border-radius: 0.8rem;\\r\\n -o-border-radius: 0.8rem;\\r\\n}\\r\\n\\r\\n @media only screen and (max-width: 576px) {\\r\\n ::-webkit-scrollbar{\\r\\n position: absolute;\\r\\n width: 0 !important;\\r\\n height: 0 !important;\\r\\n opacity: 0 !important;\\r\\n }\\r\\n ::-webkit-scrollbar-track {\\r\\n opacity: 0;\\r\\n visibility: hidden;\\r\\n background: transparent;\\r\\n }\\r\\n ::-webkit-scrollbar-thumb ,::-webkit-scrollbar-thumb:hover{\\r\\n opacity: 0;\\r\\n visibility: hidden;\\r\\n background: transparent;\\r\\n }\\r\\n }\"],\"sourceRoot\":\"\"}]);\n// Exports\nexport default ___CSS_LOADER_EXPORT___;\n","// Imports\nimport ___CSS_LOADER_API_SOURCEMAP_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/sourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/api.js\";\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_SOURCEMAP_IMPORT___);\n___CSS_LOADER_EXPORT___.push([module.id, \"@import url(https://fonts.googleapis.com/css2?family=Almarai&family=Cairo&family=Cairo+Play&family=Changa:wght@400;500&family=Mada&family=Reem+Kufi:wght@400;500&family=Satisfy&display=swap);\"]);\n___CSS_LOADER_EXPORT___.push([module.id, \"@import url(https://fonts.googleapis.com/css2?family=Alexandria:wght@300&family=Almarai:wght@300&family=Amiri&family=Amiri+Quran&family=Aref+Ruqaa&family=Aref+Ruqaa+Ink&family=Baloo+Bhaijaan+2&family=Blaka&family=Blaka+Hollow&family=Blaka+Ink&family=Cairo+Play:wght@300&family=Cairo:wght@300&family=Changa:wght@300&family=El+Messiri&family=Harmattan&family=IBM+Plex+Sans+Arabic:wght@300&family=Jomhuria&family=Katibeh&family=Kufam&family=Lalezar&family=Lateef:wght@300&family=Lemonada:wght@300&family=Mada:wght@300&family=Marhey:wght@300&family=Markazi+Text&family=Mirza&family=Noto+Kufi+Arabic:wght@300&family=Noto+Naskh+Arabic&family=Noto+Nastaliq+Urdu&family=Noto+Sans+Arabic:wght@300&family=Qahiri&family=Readex+Pro:wght@300&family=Reem+Kufi&family=Reem+Kufi+Fun&family=Reem+Kufi+Ink&family=Scheherazade+New&family=Tajawal:wght@300&family=Vibes&display=swap);\"]);\n___CSS_LOADER_EXPORT___.push([module.id, \"@import url(https://fonts.googleapis.com/css2?family=Abel&family=Alexandria:wght@300&family=Almarai:wght@300&family=Amiri&family=Amiri+Quran&family=Anton&family=Anuphan:wght@300&family=Aref+Ruqaa&family=Aref+Ruqaa+Ink&family=Baloo+Bhaijaan+2&family=Barlow+Semi+Condensed:wght@300;400;500&family=Bebas+Neue&family=Bitter:wght@300&family=Blaka&family=Blaka+Hollow&family=Blaka+Ink&family=Bruno+Ace&family=Bruno+Ace+SC&family=Cabin&family=Cairo+Play:wght@300&family=Cairo:wght@300&family=Cardo:wght@400;700&family=Carlito&family=Caveat:wght@400;500;600&family=Chakra+Petch:wght@300;400&family=Changa:wght@300&family=Chivo+Mono:wght@300&family=Comfortaa:wght@300&family=Cormorant:wght@300;400&family=Courgette&family=Crimson+Text&family=Dancing+Script:wght@400;500;600&family=EB+Garamond&family=El+Messiri&family=Exo+2:wght@300&family=Figtree:wght@300;400&family=Fira+Sans:wght@300&family=Fjalla+One&family=Great+Vibes&family=Harmattan&family=IBM+Plex+Mono:wght@300;400&family=IBM+Plex+Sans+Arabic:wght@300&family=Imbue:wght@300;400&family=Indie+Flower&family=Instrument+Serif&family=Jomhuria&family=Josefin+Sans:wght@300&family=Kalam:wght@300;400&family=Katibeh&family=Kufam&family=Lalezar&family=Lateef:wght@300&family=Lato:wght@300&family=Lemonada:wght@300&family=Libre+Baskerville&family=Lilita+One&family=Lobster&family=Lobster+Two:ital@0;1&family=Mada:wght@300&family=Marhey:wght@300&family=Markazi+Text&family=Merriweather:wght@300&family=Mirza&family=Montserrat+Alternates:wght@300;400&family=Montserrat:wght@300&family=Noticia+Text&family=Noto+Kufi+Arabic:wght@300&family=Noto+Naskh+Arabic&family=Noto+Nastaliq+Urdu&family=Noto+Sans+Arabic:wght@300&family=Noto+Serif&family=Oswald:wght@300&family=Oxygen:wght@300&family=Pacifico&family=Patua+One&family=Permanent+Marker&family=Playfair+Display&family=Poppins:wght@300&family=Prompt:wght@300&family=Qahiri&family=Questrial&family=Quicksand:wght@300&family=Raleway:wght@300&family=Readex+Pro:wght@300&family=Reem+Kufi&family=Reem+Kufi+Fun&family=Reem+Kufi+Ink&family=Righteous&family=Roboto+Mono:wght@300&family=Roboto+Slab:wght@300&family=Satisfy&family=Scheherazade+New&family=Schibsted+Grotesk&family=Sedgwick+Ave+Display&family=Sigmar&family=Signika+Negative:wght@300&family=Source+Code+Pro:wght@300;400&family=Source+Serif+Pro:wght@300&family=Space+Mono&family=Tajawal:wght@300&family=Teko:wght@300&family=Ubuntu:wght@300&family=Vibes&family=Vina+Sans&family=Yanone+Kaffeesatz:wght@300;400&family=Yellowtail&family=Ysabeau:wght@300&display=swap);\"]);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, \":root {\\r\\n /* color-variables */\\r\\n --cbmis-blue: #1769aa;\\r\\n --cbmis-indigo: #6610f2;\\r\\n --cbmis-purple: #6f42c1;\\r\\n --cbmis-pink: #e91e63;\\r\\n --cbmis-red: #dc3545;\\r\\n --cbmis-orange: #fd7e14;\\r\\n --cbmis-yellow: #ffcc00;\\r\\n --cbmis-green: #198754;\\r\\n --cbmis-teal: #20c997;\\r\\n --cbmis-cyan: #0dcaf0;\\r\\n --cbmis-white: #fff;\\r\\n --cbmis-gray-100: #f8f9fa;\\r\\n --cbmis-gray-200: #e9ecef;\\r\\n --cbmis-gray-300: #dee2e6;\\r\\n --cbmis-gray-400: #ced4da;\\r\\n --cbmis-gray-500: #adb5bd;\\r\\n --cbmis-gray-600: #6c757d;\\r\\n --cbmis-gray-700: #495057;\\r\\n --cbmis-gray-800: #343a40;\\r\\n --cbmis-gray-900: #212529;\\r\\n --cbmis-black: #000;\\r\\n --cbmis_disabled : #ced1d5;\\r\\n\\r\\n \\r\\n \\r\\n \\r\\n /* theme-color-variables */\\r\\n --cbmis-gray: var(--cbmis-gray-600);\\r\\n --cbmis-dark: var(--cbmis-gray-800);\\r\\n --cbmis-primary: var(--cbmis-blue);\\r\\n --cbmis-secondary: var(--cbmis-purple);\\r\\n --cbmis-success: var(--cbmis-green);\\r\\n --cbmis-info: var(--cbmis-cyan);\\r\\n --cbmis-warning: var(--cbmis-yellow);\\r\\n --cbmis-error: var(--cbmis-red);\\r\\n --cbmis-light: var(--cbmis-gray-100);\\r\\n \\r\\n /* color-variables-rgb */\\r\\n --cbmis-blue-rgb: 13, 109, 253;\\r\\n --cbmis-indigo-rgb: 102, 16, 242;\\r\\n --cbmis-purple-rgb: 111, 66, 193;\\r\\n --cbmis-pink-rgb: 214, 51, 132;\\r\\n --cbmis-red-rgb: 220, 53, 69;\\r\\n --cbmis-orange-rgb: 253, 126, 20;\\r\\n --cbmis-yellow-rgb: 255, 193, 7;\\r\\n --cbmis-green-rgb: 25, 135, 84;\\r\\n --cbmis-teal-rgb: 32, 201, 151;\\r\\n --cbmis-cyan-rgb: 13, 202, 240;\\r\\n \\r\\n --cbmis-primary-rgb: 13, 110, 253;\\r\\n --cbmis-secondary-rgb: 108, 117, 125;\\r\\n --cbmis-success-rgb: 25, 135, 84;\\r\\n --cbmis-info-rgb: 13, 202, 240;\\r\\n --cbmis-warning-rgb: 255, 193, 7;\\r\\n --cbmis-error-rgb: 220, 53, 69;\\r\\n --cbmis-light-rgb: 248, 249, 250;\\r\\n --cbmis-dark-rgb: 33, 37, 41;\\r\\n --cbmis-white-rgb: 255, 255, 255;\\r\\n --cbmis-black-rgb: 0, 0, 0;\\r\\n \\r\\n /* color contrast */\\r\\n --cbmis-min-contrast-ratio:4.5;\\r\\n --cbmis-color-contrast-dark:var(--cbmis-black);\\r\\n --cbmis-color-contrast-light:var(--cbmis-white);\\r\\n --cbmis-gradient: linear-gradient(180deg, rgba(255, 255, 255, 0.15), rgba(255, 255, 255, 0));\\r\\n \\r\\n /* ratio color */\\r\\n --cbmis-blue-100: rgba(var(--cbmis-blue-rgb), 10%);\\r\\n --cbmis-blue-200: rgba(var(--cbmis-blue-rgb), 20%);\\r\\n --cbmis-blue-300: rgba(var(--cbmis-blue-rgb), 30%);\\r\\n --cbmis-blue-400: rgba(var(--cbmis-blue-rgb), 40%);\\r\\n --cbmis-blue-500: rgba(var(--cbmis-blue-rgb), 50%);\\r\\n --cbmis-blue-600: rgba(var(--cbmis-blue-rgb), 60%);\\r\\n --cbmis-blue-700: rgba(var(--cbmis-blue-rgb), 70%);\\r\\n --cbmis-blue-800: rgba(var(--cbmis-blue-rgb), 80%);\\r\\n --cbmis-blue-900: rgba(var(--cbmis-blue-rgb), 90%);\\r\\n \\r\\n --cbmis-indigo-100: rgba(var(--cbmis-indigo-rgb), 10%);\\r\\n --cbmis-indigo-200: rgba(var(--cbmis-indigo-rgb), 20%);\\r\\n --cbmis-indigo-300: rgba(var(--cbmis-indigo-rgb), 30%);\\r\\n --cbmis-indigo-400: rgba(var(--cbmis-indigo-rgb), 40%);\\r\\n --cbmis-indigo-500: rgba(var(--cbmis-indigo-rgb), 50%);\\r\\n --cbmis-indigo-600: rgba(var(--cbmis-indigo-rgb), 60%);\\r\\n --cbmis-indigo-700: rgba(var(--cbmis-indigo-rgb), 70%);\\r\\n --cbmis-indigo-800: rgba(var(--cbmis-indigo-rgb), 80%);\\r\\n --cbmis-indigo-900: rgba(var(--cbmis-indigo-rgb), 90%);\\r\\n \\r\\n --cbmis-purple-100: rgba(var(--cbmis-purple-rgb), 10%);\\r\\n --cbmis-purple-200: rgba(var(--cbmis-purple-rgb), 20%);\\r\\n --cbmis-purple-300: rgba(var(--cbmis-purple-rgb), 30%);\\r\\n --cbmis-purple-400: rgba(var(--cbmis-purple-rgb), 40%);\\r\\n --cbmis-purple-500: rgba(var(--cbmis-purple-rgb), 50%);\\r\\n --cbmis-purple-600: rgba(var(--cbmis-purple-rgb), 60%);\\r\\n --cbmis-purple-700: rgba(var(--cbmis-purple-rgb), 70%);\\r\\n --cbmis-purple-800: rgba(var(--cbmis-purple-rgb), 80%);\\r\\n --cbmis-purple-900: rgba(var(--cbmis-purple-rgb), 90%);\\r\\n \\r\\n --cbmis-pink-100: rgba(var(--cbmis-pink-rgb), 10%);\\r\\n --cbmis-pink-200: rgba(var(--cbmis-pink-rgb), 20%);\\r\\n --cbmis-pink-300: rgba(var(--cbmis-pink-rgb), 30%);\\r\\n --cbmis-pink-400: rgba(var(--cbmis-pink-rgb), 40%);\\r\\n --cbmis-pink-500: rgba(var(--cbmis-pink-rgb), 50%);\\r\\n --cbmis-pink-600: rgba(var(--cbmis-pink-rgb), 60%);\\r\\n --cbmis-pink-700: rgba(var(--cbmis-pink-rgb), 70%);\\r\\n --cbmis-pink-800: rgba(var(--cbmis-pink-rgb), 80%);\\r\\n --cbmis-pink-900: rgba(var(--cbmis-pink-rgb), 90%);\\r\\n \\r\\n --cbmis-red-100: rgba(var(--cbmis-red-rgb), 10%);\\r\\n --cbmis-red-200: rgba(var(--cbmis-red-rgb), 20%);\\r\\n --cbmis-red-300: rgba(var(--cbmis-red-rgb), 30%);\\r\\n --cbmis-red-400: rgba(var(--cbmis-red-rgb), 40%);\\r\\n --cbmis-red-500: rgba(var(--cbmis-red-rgb), 50%);\\r\\n --cbmis-red-600: rgba(var(--cbmis-red-rgb), 60%);\\r\\n --cbmis-red-700: rgba(var(--cbmis-red-rgb), 70%);\\r\\n --cbmis-red-800: rgba(var(--cbmis-red-rgb), 80%);\\r\\n --cbmis-red-900: rgba(var(--cbmis-red-rgb), 90%);\\r\\n \\r\\n --cbmis-orange-100: rgba(var(--cbmis-orange-rgb), 10%);\\r\\n --cbmis-orange-200: rgba(var(--cbmis-orange-rgb), 20%);\\r\\n --cbmis-orange-300: rgba(var(--cbmis-orange-rgb), 30%);\\r\\n --cbmis-orange-400: rgba(var(--cbmis-orange-rgb), 40%);\\r\\n --cbmis-orange-500: rgba(var(--cbmis-orange-rgb), 50%);\\r\\n --cbmis-orange-600: rgba(var(--cbmis-orange-rgb), 60%);\\r\\n --cbmis-orange-700: rgba(var(--cbmis-orange-rgb), 70%);\\r\\n --cbmis-orange-800: rgba(var(--cbmis-orange-rgb), 80%);\\r\\n --cbmis-orange-900: rgba(var(--cbmis-orange-rgb), 90%);\\r\\n \\r\\n --cbmis-yellow-100: rgba(var(--cbmis-yellow-rgb), 10%);\\r\\n --cbmis-yellow-200: rgba(var(--cbmis-yellow-rgb), 20%);\\r\\n --cbmis-yellow-300: rgba(var(--cbmis-yellow-rgb), 30%);\\r\\n --cbmis-yellow-400: rgba(var(--cbmis-yellow-rgb), 40%);\\r\\n --cbmis-yellow-500: rgba(var(--cbmis-yellow-rgb), 50%);\\r\\n --cbmis-yellow-600: rgba(var(--cbmis-yellow-rgb), 60%);\\r\\n --cbmis-yellow-700: rgba(var(--cbmis-yellow-rgb), 70%);\\r\\n --cbmis-yellow-800: rgba(var(--cbmis-yellow-rgb), 80%);\\r\\n --cbmis-yellow-900: rgba(var(--cbmis-yellow-rgb), 90%);\\r\\n \\r\\n --cbmis-green-100: rgba(var(--cbmis-green-rgb), 10%);\\r\\n --cbmis-green-200: rgba(var(--cbmis-green-rgb), 20%);\\r\\n --cbmis-green-300: rgba(var(--cbmis-green-rgb), 30%);\\r\\n --cbmis-green-400: rgba(var(--cbmis-green-rgb), 40%);\\r\\n --cbmis-green-500: rgba(var(--cbmis-green-rgb), 50%);\\r\\n --cbmis-green-600: rgba(var(--cbmis-green-rgb), 60%);\\r\\n --cbmis-green-700: rgba(var(--cbmis-green-rgb), 70%);\\r\\n --cbmis-green-800: rgba(var(--cbmis-green-rgb), 80%);\\r\\n --cbmis-green-900: rgba(var(--cbmis-green-rgb), 90%);\\r\\n \\r\\n --cbmis-teal-100: rgba(var(--cbmis-teal-rgb), 10%);\\r\\n --cbmis-teal-200: rgba(var(--cbmis-teal-rgb), 20%);\\r\\n --cbmis-teal-300: rgba(var(--cbmis-teal-rgb), 30%);\\r\\n --cbmis-teal-400: rgba(var(--cbmis-teal-rgb), 40%);\\r\\n --cbmis-teal-500: rgba(var(--cbmis-teal-rgb), 50%);\\r\\n --cbmis-teal-600: rgba(var(--cbmis-teal-rgb), 60%);\\r\\n --cbmis-teal-700: rgba(var(--cbmis-teal-rgb), 70%);\\r\\n --cbmis-teal-800: rgba(var(--cbmis-teal-rgb), 80%);\\r\\n --cbmis-teal-900: rgba(var(--cbmis-teal-rgb), 90%);\\r\\n \\r\\n --cbmis-cyan-100: rgba(var(--cbmis-cyan-rgb), 10%);\\r\\n --cbmis-cyan-200: rgba(var(--cbmis-cyan-rgb), 20%);\\r\\n --cbmis-cyan-300: rgba(var(--cbmis-cyan-rgb), 30%);\\r\\n --cbmis-cyan-400: rgba(var(--cbmis-cyan-rgb), 40%);\\r\\n --cbmis-cyan-500: rgba(var(--cbmis-cyan-rgb), 50%);\\r\\n --cbmis-cyan-600: rgba(var(--cbmis-cyan-rgb), 60%);\\r\\n --cbmis-cyan-700: rgba(var(--cbmis-cyan-rgb), 70%);\\r\\n --cbmis-cyan-800: rgba(var(--cbmis-cyan-rgb), 80%);\\r\\n --cbmis-cyan-900: rgba(var(--cbmis-cyan-rgb), 90%); \\r\\n \\r\\n --cbmis-primary-100: rgba(var(--cbmis-primary-rgb), 10%);\\r\\n --cbmis-primary-200: rgba(var(--cbmis-primary-rgb), 20%);\\r\\n --cbmis-primary-300: rgba(var(--cbmis-primary-rgb), 30%);\\r\\n --cbmis-primary-400: rgba(var(--cbmis-primary-rgb), 40%);\\r\\n --cbmis-primary-500: rgba(var(--cbmis-primary-rgb), 50%);\\r\\n --cbmis-primary-600: rgba(var(--cbmis-primary-rgb), 60%);\\r\\n --cbmis-primary-700: rgba(var(--cbmis-primary-rgb), 70%);\\r\\n --cbmis-primary-800: rgba(var(--cbmis-primary-rgb), 80%);\\r\\n --cbmis-primary-900: rgba(var(--cbmis-primary-rgb), 90%); \\r\\n \\r\\n --cbmis-secondary-100: rgba(var(--cbmis-secondary-rgb), 10%);\\r\\n --cbmis-secondary-200: rgba(var(--cbmis-secondary-rgb), 20%);\\r\\n --cbmis-secondary-300: rgba(var(--cbmis-secondary-rgb), 30%);\\r\\n --cbmis-secondary-400: rgba(var(--cbmis-secondary-rgb), 40%);\\r\\n --cbmis-secondary-500: rgba(var(--cbmis-secondary-rgb), 50%);\\r\\n --cbmis-secondary-600: rgba(var(--cbmis-secondary-rgb), 60%);\\r\\n --cbmis-secondary-700: rgba(var(--cbmis-secondary-rgb), 70%);\\r\\n --cbmis-secondary-800: rgba(var(--cbmis-secondary-rgb), 80%);\\r\\n --cbmis-secondary-900: rgba(var(--cbmis-secondary-rgb), 90%);\\r\\n \\r\\n --cbmis-success-100: rgba(var(--cbmis-success-rgb), 10%);\\r\\n --cbmis-success-200: rgba(var(--cbmis-success-rgb), 20%);\\r\\n --cbmis-success-300: rgba(var(--cbmis-success-rgb), 30%);\\r\\n --cbmis-success-400: rgba(var(--cbmis-success-rgb), 40%);\\r\\n --cbmis-success-500: rgba(var(--cbmis-success-rgb), 50%);\\r\\n --cbmis-success-600: rgba(var(--cbmis-success-rgb), 60%);\\r\\n --cbmis-success-700: rgba(var(--cbmis-success-rgb), 70%);\\r\\n --cbmis-success-800: rgba(var(--cbmis-success-rgb), 80%);\\r\\n --cbmis-success-900: rgba(var(--cbmis-success-rgb), 90%);\\r\\n \\r\\n --cbmis-info-100: rgba(var(--cbmis-info-rgb), 10%);\\r\\n --cbmis-info-200: rgba(var(--cbmis-info-rgb), 20%);\\r\\n --cbmis-info-300: rgba(var(--cbmis-info-rgb), 30%);\\r\\n --cbmis-info-400: rgba(var(--cbmis-info-rgb), 40%);\\r\\n --cbmis-info-500: rgba(var(--cbmis-info-rgb), 50%);\\r\\n --cbmis-info-600: rgba(var(--cbmis-info-rgb), 60%);\\r\\n --cbmis-info-700: rgba(var(--cbmis-info-rgb), 70%);\\r\\n --cbmis-info-800: rgba(var(--cbmis-info-rgb), 80%);\\r\\n --cbmis-info-900: rgba(var(--cbmis-info-rgb), 90%); \\r\\n \\r\\n --cbmis-warning-100: rgba(var(--cbmis-warning-rgb), 10%);\\r\\n --cbmis-warning-200: rgba(var(--cbmis-warning-rgb), 20%);\\r\\n --cbmis-warning-300: rgba(var(--cbmis-warning-rgb), 30%);\\r\\n --cbmis-warning-400: rgba(var(--cbmis-warning-rgb), 40%);\\r\\n --cbmis-warning-500: rgba(var(--cbmis-warning-rgb), 50%);\\r\\n --cbmis-warning-600: rgba(var(--cbmis-warning-rgb), 60%);\\r\\n --cbmis-warning-700: rgba(var(--cbmis-warning-rgb), 70%);\\r\\n --cbmis-warning-800: rgba(var(--cbmis-warning-rgb), 80%);\\r\\n --cbmis-warning-900: rgba(var(--cbmis-warning-rgb), 90%); \\r\\n \\r\\n --cbmis-error-100: rgba(var(--cbmis-error-rgb), 10%);\\r\\n --cbmis-error-200: rgba(var(--cbmis-error-rgb), 20%);\\r\\n --cbmis-error-300: rgba(var(--cbmis-error-rgb), 30%);\\r\\n --cbmis-error-400: rgba(var(--cbmis-error-rgb), 40%);\\r\\n --cbmis-error-500: rgba(var(--cbmis-error-rgb), 50%);\\r\\n --cbmis-error-600: rgba(var(--cbmis-error-rgb), 60%);\\r\\n --cbmis-error-700: rgba(var(--cbmis-error-rgb), 70%);\\r\\n --cbmis-error-800: rgba(var(--cbmis-error-rgb), 80%);\\r\\n --cbmis-error-900: rgba(var(--cbmis-error-rgb), 90%); \\r\\n \\r\\n --cbmis-light-100: rgba(var(--cbmis-light-rgb), 10%);\\r\\n --cbmis-light-200: rgba(var(--cbmis-light-rgb), 20%);\\r\\n --cbmis-light-300: rgba(var(--cbmis-light-rgb), 30%);\\r\\n --cbmis-light-400: rgba(var(--cbmis-light-rgb), 40%);\\r\\n --cbmis-light-500: rgba(var(--cbmis-light-rgb), 50%);\\r\\n --cbmis-light-600: rgba(var(--cbmis-light-rgb), 60%);\\r\\n --cbmis-light-700: rgba(var(--cbmis-light-rgb), 70%);\\r\\n --cbmis-light-800: rgba(var(--cbmis-light-rgb), 80%);\\r\\n --cbmis-light-900: rgba(var(--cbmis-light-rgb), 90%); \\r\\n \\r\\n --cbmis-dark-100: rgba(var(--cbmis-dark-rgb), 10%);\\r\\n --cbmis-dark-200: rgba(var(--cbmis-dark-rgb), 20%);\\r\\n --cbmis-dark-300: rgba(var(--cbmis-dark-rgb), 30%);\\r\\n --cbmis-dark-400: rgba(var(--cbmis-dark-rgb), 40%);\\r\\n --cbmis-dark-500: rgba(var(--cbmis-dark-rgb), 50%);\\r\\n --cbmis-dark-600: rgba(var(--cbmis-dark-rgb), 60%);\\r\\n --cbmis-dark-700: rgba(var(--cbmis-dark-rgb), 70%);\\r\\n --cbmis-dark-800: rgba(var(--cbmis-dark-rgb), 80%);\\r\\n --cbmis-dark-900: rgba(var(--cbmis-dark-rgb), 90%); \\r\\n \\r\\n --cbmis-white-100: rgba(var(--cbmis-white-rgb), 10%);\\r\\n --cbmis-white-200: rgba(var(--cbmis-white-rgb), 20%);\\r\\n --cbmis-white-300: rgba(var(--cbmis-white-rgb), 30%);\\r\\n --cbmis-white-400: rgba(var(--cbmis-white-rgb), 40%);\\r\\n --cbmis-white-500: rgba(var(--cbmis-white-rgb), 50%);\\r\\n --cbmis-white-600: rgba(var(--cbmis-white-rgb), 60%);\\r\\n --cbmis-white-700: rgba(var(--cbmis-white-rgb), 70%);\\r\\n --cbmis-white-800: rgba(var(--cbmis-white-rgb), 80%);\\r\\n --cbmis-white-900: rgba(var(--cbmis-white-rgb), 90%); \\r\\n \\r\\n --cbmis-black-100: rgba(var(--cbmis-black-rgb), 10%);\\r\\n --cbmis-black-200: rgba(var(--cbmis-black-rgb), 20%);\\r\\n --cbmis-black-300: rgba(var(--cbmis-black-rgb), 30%);\\r\\n --cbmis-black-400: rgba(var(--cbmis-black-rgb), 40%);\\r\\n --cbmis-black-500: rgba(var(--cbmis-black-rgb), 50%);\\r\\n --cbmis-black-600: rgba(var(--cbmis-black-rgb), 60%);\\r\\n --cbmis-black-700: rgba(var(--cbmis-black-rgb), 70%);\\r\\n --cbmis-black-800: rgba(var(--cbmis-black-rgb), 80%);\\r\\n --cbmis-black-900: rgba(var(--cbmis-black-rgb), 90%); \\r\\n \\r\\n --cbmis-input-color:var(--cbmis-gray-600);\\r\\n --cbmis-input-color-focus:var(--cbmis-primary);\\r\\n \\r\\n /* body values */\\r\\n --cbmis-body-font-family: var(--cbmis-font-sans-serif);\\r\\n --cbmis-body-font-size: 1rem;\\r\\n --cbmis-body-font-weight: 500;\\r\\n --cbmis-body-line-height: 1.5;\\r\\n --cbmis-body-color-dark: var(--cbmis-dark-700);\\r\\n --cbmis-body-color-gray: var(--cbmis-gray-700);\\r\\n --cbmis-body-color: var(--cbmis-gray-700);\\r\\n --cbmis-body-color-light: var(--cbmis-gray-200);\\r\\n --cbmis-body-bg: var(--cbmis-white);\\r\\n --cbmis-body-text-align:none;\\r\\n \\r\\n /* links Style anchor elements */\\r\\n --cbmis-link-color:var(--cbmis-primary);\\r\\n --cbmis-link-decoration:underline;\\r\\n --cbmis-link-hover-color: var(--cbmis-primary-200);\\r\\n --cbmis-link-hover-decoration: none;\\r\\n \\r\\n /* border-variables */\\r\\n --cbmis-border-width-1: 1px;\\r\\n --cbmis-border-width-2: 2px;\\r\\n --cbmis-border-width-3: 3px;\\r\\n --cbmis-border-width-4: 4px;\\r\\n --cbmis-border-width-5: 5px;\\r\\n --cbmis-border-color:var(--cbmis-gray-300);\\r\\n --cbmis-border-radius:.5rem;\\r\\n --cbmis-border-radius-sm:.2rem;\\r\\n --cbmis-border-radius-md:.4rem;\\r\\n --cbmis-border-radius-lg:.8rem;\\r\\n --cbmis-border-radius-xl:1rem;\\r\\n --cbmis-border-radius-pill:100%;\\r\\n \\r\\n /* box-shadow-variables */\\r\\n --cbmis-box-shadow: 1px 4px 2px -2px var(--cbmis-black-200), 1px 3px 3px 1px var(--cbmis-black-200), 1px 2px 6px 1px var(--cbmis-black-200);\\r\\n /* --cbmis-box-shadow-1: 0px 3px 1px -2px var(--cbmis-black-200), 0px 2px 2px 0px var(--cbmis-black-200), 0px 1px 5px 0px var(--cbmis-black-100); */\\r\\n --cbmis-box-shadow-1: rgb(0 0 0 / 20%) 0px 2px 1px -1px, rgb(0 0 0 / 14%) 0px 1px 1px 0px, rgb(0 0 0 / 12%) 0px 1px 3px 0px;\\r\\n --cbmis-box-shadow-2: var(--cbmis-border-color) 0px 8px 24px;\\r\\n --cbmis-box-shadow-3: var(--cbmis-black-300) 0px 5px 15px ;\\r\\n --cbmis-box-shadow-4: var(--cbmis-black-200) 0px 1px 4px, var(--cbmis-border-color) 0px 0px 0px 3px;;\\r\\n --cbmis-box-shadow-5: var(--cbmis-black-200) 0px 54px 55px, var(--cbmis-black-100) 0px -12px 30px, var(--cbmis-black-100) 0px 4px 6px, var(--cbmis-black-200) 0px 12px 13px, var(--cbmis-black-100) 0px -3px 5px;\\r\\n --cbmis-box-shadow-inset-1: var(--cbmis-border-color) 0px 50px 100px -20px, var(--cbmis-black-300) 0px 30px 60px -30px, var(--cbmis-dark-200) 0px -2px 6px 0px inset;\\r\\n --cbmis-box-shadow-inset-2: var(--cbmis-border-color) 0px 30px 60px -12px inset, var(--cbmis-black-300) 0px 18px 36px -18px inset;\\r\\n --cbmis-box-shadow-inset-3: var(--cbmis-border-color) 3px 3px 6px 0px inset, var(--cbmis-black-500) -3px -3px 6px 1px inset;\\r\\n --cbmis-box-shadow-inset-4: var(--cbmis-black-200) 0px -23px 25px 0px inset, var(--cbmis-black-100) 0px -36px 30px 0px inset, var(--cbmis-black-100) 0px -79px 40px 0px inset, var(--cbmis-black-100) 0px 2px 1px, var(--cbmis-black-100) 0px 4px 2px, var(--cbmis-black-100) 0px 8px 4px, var(--cbmis-black-100) 0px 16px 8px, var(--cbmis-black-200) 0px 32px 16px;\\r\\n --cbmis-box-shadow-inset-5: var(--cbmis-black-400) 0px 2px 4px, var(--cbmis-black-300) 0px 7px 13px -3px, var(--cbmis-black-200) 0px -3px 0px inset;\\r\\n \\r\\n /*box-size-variable */\\r\\n --cbmis-border-box-sizing: border-box;\\r\\n --cbmis-content-box-sizing: content-box;\\r\\n --cbmis-inherit-box-sizing: inherit;\\r\\n \\r\\n /*spacer-variables */\\r\\n --cbmis-spacer: 1rem;\\r\\n --cbmis-spacer-0: 0;\\r\\n --cbmis-spacer-1: .25rem;\\r\\n --cbmis-spacer-2: .5rem;\\r\\n --cbmis-spacer-3: var(--cbmis-spacer);\\r\\n --cbmis-spacer-4: 1.5rem;\\r\\n --cbmis-spacer-5: 3rem;\\r\\n \\r\\n /* Font */\\r\\n --cbmis-font-family-sans-serif: system-ui, -apple-system, \\\"Segoe UI\\\", Roboto, \\\"Helvetica Neue\\\", Arial, \\\"Noto Sans\\\", \\\"Liberation Sans\\\", sans-serif, \\\"Apple Color Emoji\\\", \\\"Segoe UI Emoji\\\", \\\"Segoe UI Symbol\\\", \\\"Noto Color Emoji\\\" ;\\r\\n --cbmis-font-family-monospace: SFMono-Regular, Menlo, Monaco, Consolas, \\\"Liberation Mono\\\", \\\"Courier New\\\", monospace ;\\r\\n --cbmis-font-family-Roboto:\\\"Roboto\\\", \\\"Helvetica\\\", \\\"Arial\\\", sans-serif;\\r\\n \\r\\n --cbmis-font-size: 1rem ; \\r\\n --cbmis-font-size-xs: .75rem ;\\r\\n --cbmis-font-size-sm: 1rem ;\\r\\n --cbmis-font-size-md: 1.25rem ;\\r\\n --cbmis-font-size-lg: 1.5rem;\\r\\n --cbmis-font-size-xl: 2rem;\\r\\n --cbmis-font-size-icon :1.20rem;\\r\\n \\r\\n --cbmis-font-weight-lighter: lighter;\\r\\n --cbmis-font-weight-light: 300;\\r\\n --cbmis-font-weight-normal: 400;\\r\\n --cbmis-font-weight-bold: 600;\\r\\n --cbmis-font-weight-bolder: bolder;\\r\\n \\r\\n --cbmis-line-height: 1.5;\\r\\n --cbmis-line-height-sm: 1.25;\\r\\n --cbmis-line-height-lg: 2;\\r\\n \\r\\n --cbmis-h1-font-size: 4rem;\\r\\n --cbmis-h2-font-size: 3.5rem;\\r\\n --cbmis-h3-font-size: 3rem;\\r\\n --cbmis-h4-font-size: 2rem;\\r\\n --cbmis-h5-font-size: 1.5rem;\\r\\n --cbmis-h6-font-size: 1.25rem;\\r\\n --cbmis-subtitle1-font-size: var(--cbmis-font-size);\\r\\n --cbmis-subtitle2-font-size: 0.875rem;\\r\\n --cbmis-body1-font-size: var(--cbmis-font-size);\\r\\n --cbmis-body2-font-size: 0.875rem;\\r\\n --cbmis-caption-font-size:0.75rem;\\r\\n --cbmis-overline-font-size:0.75rem;\\r\\n \\r\\n --cbmis-font-size-1:var(--cbmis-h1-font-size);\\r\\n --cbmis-font-size-2:var(--cbmis-h2-font-size);\\r\\n --cbmis-font-size-3:var(--cbmis-h3-font-size);\\r\\n --cbmis-font-size-4:var(--cbmis-h4-font-size);\\r\\n --cbmis-font-size-5:var(--cbmis-h5-font-size);\\r\\n --cbmis-font-size-6:var(--cbmis-h6-font-size);\\r\\n \\r\\n --cbmis-width-xs: 420px;\\r\\n --cbmis-width-sm: 576px;\\r\\n --cbmis-width-md: 640px;\\r\\n --cbmis-width-lg: 920px;\\r\\n --cbmis-width-xl: 1200px;\\r\\n --cbmis-width-fluid: 100%;\\r\\n --cbmis-width-half:50%;\\r\\n \\r\\n --cbmis-width-item-xs: var(--cbmis-spacer-4);\\r\\n --cbmis-width-item-sm: var(--cbmis-spacer-5);\\r\\n --cbmis-width-item-md: 3.7rem;\\r\\n --cbmis-width-item-lg: 5rem;\\r\\n --cbmis-width-item-xl: 6rem;\\r\\n --cbmis-width-item-fluid: 100%;\\r\\n --cbmis-width-item-half:50%;\\r\\n \\r\\n --cbmis-z-index--1:-1;\\r\\n --cbmis-z-index-0:0;\\r\\n --cbmis-z-index-1:1;\\r\\n --cbmis-z-index-2:2;\\r\\n --cbmis-z-index-3:3;\\r\\n --cbmis-z-index-10:10;\\r\\n --cbmis-z-index-100:100;\\r\\n --cbmis-z-index-101:101;\\r\\n --cbmis-z-index-102:102;\\r\\n --cbmis-z-index-103:103;\\r\\n --cbmis-z-index-104:104;\\r\\n --cbmis-z-index-105:105;\\r\\n --cbmis-z-index-106:106;\\r\\n --cbmis-z-index-107:107;\\r\\n --cbmis-z-index-108:108;\\r\\n --cbmis-z-index-109:109;\\r\\n --cbmis-z-index-110:110;\\r\\n --cbmis-z-index-996:996;\\r\\n --cbmis-z-index-997:997;\\r\\n --cbmis-z-index-998:998;\\r\\n --cbmis-z-index-999:999;\\r\\n --cbmis-z-index-1000:1000;\\r\\n --cbmis-z-index-1001:1001;\\r\\n --cbmis-z-index-100000000:100000000; /*judtCamera*/\\r\\n --cbmis-z-index-100000001:100000001;\\r\\n --cbmis-z-index-100000002:100000002;\\r\\n --cbmis-z-index-100000003:100000003; /*just loader*/\\r\\n\\r\\n --cbmis-z-index-loader:1000000000; \\r\\n \\r\\n \\r\\n /* --cbmis-clip-path-circle: circle(48% at 50% 50%); */\\r\\n --cbmis-clip-path-oval: ellipse(30% 40% at 50% 50%);\\r\\n --cbmis-clip-path-triangle: polygon(50% 0%, 0% 100%, 100% 100%);\\r\\n --cbmis-clip-path-pentagon: polygon(50% 0%, 100% 38%, 82% 100%, 18% 100%, 0% 38%); \\r\\n --cbmis-clip-path-hexagon: polygon(25% 0%, 75% 0%, 100% 50%, 75% 100%, 25% 100%, 0% 50%);\\r\\n --cbmis-clip-path-heptagon: polygon(50% 0%, 90% 20%, 100% 60%, 75% 100%, 25% 100%, 0% 60%, 10% 20%);\\r\\n --cbmis-clip-path-octagon: polygon(30% 0%, 70% 0%, 100% 30%, 100% 70%, 70% 100%, 30% 100%, 0% 70%, 0% 30%); \\r\\n --cbmis-clip-path-star: polygon(50% 0%, 61% 35%, 98% 35%, 68% 57%, 79% 91%, 50% 70%, 21% 91%, 32% 57%, 2% 35%, 39% 35%); \\r\\n --cbmis-clip-path-top-chevron: polygon(0 100%, 50% 75%, 100% 100%, 100% 25%, 50% 0, 0 25%); \\r\\n --cbmis-clip-path-left-chevron: polygon(100% 0%, 75% 50%, 100% 100%, 25% 100%, 0% 50%, 25% 0%); \\r\\n --cbmis-clip-path-right-chevron: polygon(75% 0%, 100% 50%, 75% 100%, 0% 100%, 25% 50%, 0% 0%); \\r\\n --cbmis-clip-path-bottom-chevron: polygon(0 0, 50% 25%, 100% 0, 100% 75%, 50% 100%, 0 75%); \\r\\n \\r\\n /*margin*/\\r\\n --cbmis-margin-0:0;\\r\\n --cbmis-margin-1:4px;\\r\\n --cbmis-margin-2:8px;\\r\\n --cbmis-margin-3:12px;\\r\\n --cbmis-margin-4:16px;\\r\\n --cbmis-margin-5:20px;\\r\\n --cbmis-margin-6:24px;\\r\\n --cbmis-margin-7:28px;\\r\\n --cbmis-margin-8:32px;\\r\\n --cbmis-margin-9:36px;\\r\\n --cbmis-margin-10:40px;\\r\\n \\r\\n /*padding*/\\r\\n --cbmis-padding-0:0;\\r\\n --cbmis-padding-1:4px;\\r\\n --cbmis-padding-2:8px;\\r\\n --cbmis-padding-3:12px;\\r\\n --cbmis-padding-4:16px;\\r\\n --cbmis-padding-5:20px;\\r\\n --cbmis-padding-6:24px;\\r\\n --cbmis-padding-7:28px;\\r\\n --cbmis-padding-8:32px;\\r\\n --cbmis-padding-9:36px;\\r\\n --cbmis-padding-10:40px;\\r\\n}\\r\\n\", \"\",{\"version\":3,\"sources\":[\"webpack://./style/src/style/var.css\"],\"names\":[],\"mappings\":\"AAIA;IACI,oBAAoB;MAClB,qBAAqB;MACrB,uBAAuB;MACvB,uBAAuB;MACvB,qBAAqB;MACrB,oBAAoB;MACpB,uBAAuB;MACvB,uBAAuB;MACvB,sBAAsB;MACtB,qBAAqB;MACrB,qBAAqB;MACrB,mBAAmB;MACnB,yBAAyB;MACzB,yBAAyB;MACzB,yBAAyB;MACzB,yBAAyB;MACzB,yBAAyB;MACzB,yBAAyB;MACzB,yBAAyB;MACzB,yBAAyB;MACzB,yBAAyB;MACzB,mBAAmB;MACnB,0BAA0B;;;;;IAK5B,0BAA0B;MACxB,mCAAmC;MACnC,mCAAmC;MACnC,kCAAkC;MAClC,sCAAsC;MACtC,mCAAmC;MACnC,+BAA+B;MAC/B,oCAAoC;MACpC,+BAA+B;MAC/B,oCAAoC;;MAEpC,wBAAwB;MACxB,8BAA8B;MAC9B,gCAAgC;MAChC,gCAAgC;MAChC,8BAA8B;MAC9B,4BAA4B;MAC5B,gCAAgC;MAChC,+BAA+B;MAC/B,8BAA8B;MAC9B,8BAA8B;MAC9B,8BAA8B;;MAE9B,iCAAiC;MACjC,oCAAoC;MACpC,gCAAgC;MAChC,8BAA8B;MAC9B,gCAAgC;MAChC,8BAA8B;MAC9B,gCAAgC;MAChC,4BAA4B;MAC5B,gCAAgC;MAChC,0BAA0B;;MAE1B,mBAAmB;MACnB,8BAA8B;MAC9B,8CAA8C;MAC9C,+CAA+C;MAC/C,4FAA4F;;MAE5F,gBAAgB;MAChB,kDAAkD;MAClD,kDAAkD;MAClD,kDAAkD;MAClD,kDAAkD;MAClD,kDAAkD;MAClD,kDAAkD;MAClD,kDAAkD;MAClD,kDAAkD;MAClD,kDAAkD;;MAElD,sDAAsD;MACtD,sDAAsD;MACtD,sDAAsD;MACtD,sDAAsD;MACtD,sDAAsD;MACtD,sDAAsD;MACtD,sDAAsD;MACtD,sDAAsD;MACtD,sDAAsD;;MAEtD,sDAAsD;MACtD,sDAAsD;MACtD,sDAAsD;MACtD,sDAAsD;MACtD,sDAAsD;MACtD,sDAAsD;MACtD,sDAAsD;MACtD,sDAAsD;MACtD,sDAAsD;;MAEtD,kDAAkD;MAClD,kDAAkD;MAClD,kDAAkD;MAClD,kDAAkD;MAClD,kDAAkD;MAClD,kDAAkD;MAClD,kDAAkD;MAClD,kDAAkD;MAClD,kDAAkD;;MAElD,gDAAgD;MAChD,gDAAgD;MAChD,gDAAgD;MAChD,gDAAgD;MAChD,gDAAgD;MAChD,gDAAgD;MAChD,gDAAgD;MAChD,gDAAgD;MAChD,gDAAgD;;MAEhD,sDAAsD;MACtD,sDAAsD;MACtD,sDAAsD;MACtD,sDAAsD;MACtD,sDAAsD;MACtD,sDAAsD;MACtD,sDAAsD;MACtD,sDAAsD;MACtD,sDAAsD;;MAEtD,sDAAsD;MACtD,sDAAsD;MACtD,sDAAsD;MACtD,sDAAsD;MACtD,sDAAsD;MACtD,sDAAsD;MACtD,sDAAsD;MACtD,sDAAsD;MACtD,sDAAsD;;MAEtD,oDAAoD;MACpD,oDAAoD;MACpD,oDAAoD;MACpD,oDAAoD;MACpD,oDAAoD;MACpD,oDAAoD;MACpD,oDAAoD;MACpD,oDAAoD;MACpD,oDAAoD;;MAEpD,kDAAkD;MAClD,kDAAkD;MAClD,kDAAkD;MAClD,kDAAkD;MAClD,kDAAkD;MAClD,kDAAkD;MAClD,kDAAkD;MAClD,kDAAkD;MAClD,kDAAkD;;MAElD,kDAAkD;MAClD,kDAAkD;MAClD,kDAAkD;MAClD,kDAAkD;MAClD,kDAAkD;MAClD,kDAAkD;MAClD,kDAAkD;MAClD,kDAAkD;MAClD,kDAAkD;;MAElD,wDAAwD;MACxD,wDAAwD;MACxD,wDAAwD;MACxD,wDAAwD;MACxD,wDAAwD;MACxD,wDAAwD;MACxD,wDAAwD;MACxD,wDAAwD;MACxD,wDAAwD;;MAExD,4DAA4D;MAC5D,4DAA4D;MAC5D,4DAA4D;MAC5D,4DAA4D;MAC5D,4DAA4D;MAC5D,4DAA4D;MAC5D,4DAA4D;MAC5D,4DAA4D;MAC5D,4DAA4D;;MAE5D,wDAAwD;MACxD,wDAAwD;MACxD,wDAAwD;MACxD,wDAAwD;MACxD,wDAAwD;MACxD,wDAAwD;MACxD,wDAAwD;MACxD,wDAAwD;MACxD,wDAAwD;;MAExD,kDAAkD;MAClD,kDAAkD;MAClD,kDAAkD;MAClD,kDAAkD;MAClD,kDAAkD;MAClD,kDAAkD;MAClD,kDAAkD;MAClD,kDAAkD;MAClD,kDAAkD;;MAElD,wDAAwD;MACxD,wDAAwD;MACxD,wDAAwD;MACxD,wDAAwD;MACxD,wDAAwD;MACxD,wDAAwD;MACxD,wDAAwD;MACxD,wDAAwD;MACxD,wDAAwD;;MAExD,oDAAoD;MACpD,oDAAoD;MACpD,oDAAoD;MACpD,oDAAoD;MACpD,oDAAoD;MACpD,oDAAoD;MACpD,oDAAoD;MACpD,oDAAoD;MACpD,oDAAoD;;MAEpD,oDAAoD;MACpD,oDAAoD;MACpD,oDAAoD;MACpD,oDAAoD;MACpD,oDAAoD;MACpD,oDAAoD;MACpD,oDAAoD;MACpD,oDAAoD;MACpD,oDAAoD;;MAEpD,kDAAkD;MAClD,kDAAkD;MAClD,kDAAkD;MAClD,kDAAkD;MAClD,kDAAkD;MAClD,kDAAkD;MAClD,kDAAkD;MAClD,kDAAkD;MAClD,kDAAkD;;MAElD,oDAAoD;MACpD,oDAAoD;MACpD,oDAAoD;MACpD,oDAAoD;MACpD,oDAAoD;MACpD,oDAAoD;MACpD,oDAAoD;MACpD,oDAAoD;MACpD,oDAAoD;;MAEpD,oDAAoD;MACpD,oDAAoD;MACpD,oDAAoD;MACpD,oDAAoD;MACpD,oDAAoD;MACpD,oDAAoD;MACpD,oDAAoD;MACpD,oDAAoD;MACpD,oDAAoD;;MAEpD,yCAAyC;MACzC,8CAA8C;;MAE9C,gBAAgB;MAChB,sDAAsD;MACtD,4BAA4B;MAC5B,6BAA6B;MAC7B,6BAA6B;MAC7B,8CAA8C;MAC9C,8CAA8C;MAC9C,yCAAyC;MACzC,+CAA+C;MAC/C,mCAAmC;MACnC,4BAA4B;;MAE5B,gCAAgC;MAChC,uCAAuC;MACvC,iCAAiC;MACjC,kDAAkD;MAClD,mCAAmC;;IAErC,qBAAqB;MACnB,2BAA2B;MAC3B,2BAA2B;MAC3B,2BAA2B;MAC3B,2BAA2B;MAC3B,2BAA2B;MAC3B,0CAA0C;MAC1C,2BAA2B;MAC3B,8BAA8B;MAC9B,8BAA8B;MAC9B,8BAA8B;MAC9B,6BAA6B;MAC7B,+BAA+B;;IAEjC,yBAAyB;IACzB,2IAA2I;IAC3I,qJAAqJ;IACrJ,2HAA2H;IAC3H,4DAA4D;IAC5D,0DAA0D;IAC1D,mGAAmG;IACnG,gNAAgN;IAChN,oKAAoK;IACpK,iIAAiI;IACjI,2HAA2H;IAC3H,oWAAoW;IACpW,mJAAmJ;;IAEnJ,qBAAqB;IACrB,qCAAqC;IACrC,uCAAuC;IACvC,mCAAmC;;IAEnC,qBAAqB;IACrB,oBAAoB;IACpB,mBAAmB;IACnB,wBAAwB;IACxB,uBAAuB;IACvB,qCAAqC;IACrC,wBAAwB;IACxB,sBAAsB;;IAEtB,SAAS;GACV,gOAAgO;GAChO,oHAAoH;GACpH,qEAAqE;;IAEpE,wBAAwB;IACxB,6BAA6B;IAC7B,2BAA2B;IAC3B,8BAA8B;IAC9B,4BAA4B;IAC5B,0BAA0B;IAC1B,+BAA+B;;IAE/B,oCAAoC;IACpC,8BAA8B;IAC9B,+BAA+B;IAC/B,6BAA6B;IAC7B,kCAAkC;;IAElC,wBAAwB;IACxB,4BAA4B;IAC5B,yBAAyB;;KAExB,4BAA4B;KAC5B,6BAA6B;KAC7B,2BAA2B;KAC3B,2BAA2B;KAC3B,6BAA6B;KAC7B,8BAA8B;KAC9B,mDAAmD;KACnD,sCAAsC;KACtC,+CAA+C;KAC/C,kCAAkC;KAClC,iCAAiC;KACjC,kCAAkC;;KAElC,6CAA6C;KAC7C,6CAA6C;KAC7C,6CAA6C;KAC7C,6CAA6C;KAC7C,6CAA6C;KAC7C,6CAA6C;;IAE9C,uBAAuB;IACvB,uBAAuB;IACvB,uBAAuB;IACvB,uBAAuB;IACvB,wBAAwB;IACxB,yBAAyB;IACzB,sBAAsB;;IAEtB,4CAA4C;IAC5C,4CAA4C;IAC5C,6BAA6B;IAC7B,2BAA2B;IAC3B,2BAA2B;IAC3B,8BAA8B;IAC9B,2BAA2B;;IAE3B,qBAAqB;IACrB,mBAAmB;IACnB,mBAAmB;IACnB,mBAAmB;IACnB,mBAAmB;IACnB,qBAAqB;IACrB,uBAAuB;IACvB,uBAAuB;IACvB,uBAAuB;IACvB,uBAAuB;IACvB,uBAAuB;IACvB,uBAAuB;IACvB,uBAAuB;IACvB,uBAAuB;IACvB,uBAAuB;IACvB,uBAAuB;IACvB,uBAAuB;IACvB,uBAAuB;IACvB,uBAAuB;IACvB,uBAAuB;IACvB,uBAAuB;IACvB,yBAAyB;IACzB,yBAAyB;IACzB,mCAAmC,EAAE,aAAa;IAClD,mCAAmC;IACnC,mCAAmC;IACnC,mCAAmC,EAAE,cAAc;;IAEnD,iCAAiC;;;IAGjC,sDAAsD;IACtD,mDAAmD;IACnD,+DAA+D;IAC/D,iFAAiF;IACjF,wFAAwF;IACxF,mGAAmG;IACnG,0GAA0G;IAC1G,uHAAuH;IACvH,0FAA0F;IAC1F,8FAA8F;IAC9F,6FAA6F;IAC7F,0FAA0F;;IAE1F,SAAS;IACT,kBAAkB;IAClB,oBAAoB;IACpB,oBAAoB;IACpB,qBAAqB;IACrB,qBAAqB;IACrB,qBAAqB;IACrB,qBAAqB;IACrB,qBAAqB;IACrB,qBAAqB;IACrB,qBAAqB;IACrB,sBAAsB;;IAEtB,UAAU;IACV,mBAAmB;IACnB,qBAAqB;IACrB,qBAAqB;IACrB,sBAAsB;IACtB,sBAAsB;IACtB,sBAAsB;IACtB,sBAAsB;IACtB,sBAAsB;IACtB,sBAAsB;IACtB,sBAAsB;IACtB,uBAAuB;AAC3B\",\"sourcesContent\":[\"@import url('https://fonts.googleapis.com/css2?family=Almarai&family=Cairo&family=Cairo+Play&family=Changa:wght@400;500&family=Mada&family=Reem+Kufi:wght@400;500&family=Satisfy&display=swap');\\r\\n@import url('https://fonts.googleapis.com/css2?family=Alexandria:wght@300&family=Almarai:wght@300&family=Amiri&family=Amiri+Quran&family=Aref+Ruqaa&family=Aref+Ruqaa+Ink&family=Baloo+Bhaijaan+2&family=Blaka&family=Blaka+Hollow&family=Blaka+Ink&family=Cairo+Play:wght@300&family=Cairo:wght@300&family=Changa:wght@300&family=El+Messiri&family=Harmattan&family=IBM+Plex+Sans+Arabic:wght@300&family=Jomhuria&family=Katibeh&family=Kufam&family=Lalezar&family=Lateef:wght@300&family=Lemonada:wght@300&family=Mada:wght@300&family=Marhey:wght@300&family=Markazi+Text&family=Mirza&family=Noto+Kufi+Arabic:wght@300&family=Noto+Naskh+Arabic&family=Noto+Nastaliq+Urdu&family=Noto+Sans+Arabic:wght@300&family=Qahiri&family=Readex+Pro:wght@300&family=Reem+Kufi&family=Reem+Kufi+Fun&family=Reem+Kufi+Ink&family=Scheherazade+New&family=Tajawal:wght@300&family=Vibes&display=swap');\\r\\n@import url('https://fonts.googleapis.com/css2?family=Abel&family=Alexandria:wght@300&family=Almarai:wght@300&family=Amiri&family=Amiri+Quran&family=Anton&family=Anuphan:wght@300&family=Aref+Ruqaa&family=Aref+Ruqaa+Ink&family=Baloo+Bhaijaan+2&family=Barlow+Semi+Condensed:wght@300;400;500&family=Bebas+Neue&family=Bitter:wght@300&family=Blaka&family=Blaka+Hollow&family=Blaka+Ink&family=Bruno+Ace&family=Bruno+Ace+SC&family=Cabin&family=Cairo+Play:wght@300&family=Cairo:wght@300&family=Cardo:wght@400;700&family=Carlito&family=Caveat:wght@400;500;600&family=Chakra+Petch:wght@300;400&family=Changa:wght@300&family=Chivo+Mono:wght@300&family=Comfortaa:wght@300&family=Cormorant:wght@300;400&family=Courgette&family=Crimson+Text&family=Dancing+Script:wght@400;500;600&family=EB+Garamond&family=El+Messiri&family=Exo+2:wght@300&family=Figtree:wght@300;400&family=Fira+Sans:wght@300&family=Fjalla+One&family=Great+Vibes&family=Harmattan&family=IBM+Plex+Mono:wght@300;400&family=IBM+Plex+Sans+Arabic:wght@300&family=Imbue:wght@300;400&family=Indie+Flower&family=Instrument+Serif&family=Jomhuria&family=Josefin+Sans:wght@300&family=Kalam:wght@300;400&family=Katibeh&family=Kufam&family=Lalezar&family=Lateef:wght@300&family=Lato:wght@300&family=Lemonada:wght@300&family=Libre+Baskerville&family=Lilita+One&family=Lobster&family=Lobster+Two:ital@0;1&family=Mada:wght@300&family=Marhey:wght@300&family=Markazi+Text&family=Merriweather:wght@300&family=Mirza&family=Montserrat+Alternates:wght@300;400&family=Montserrat:wght@300&family=Noticia+Text&family=Noto+Kufi+Arabic:wght@300&family=Noto+Naskh+Arabic&family=Noto+Nastaliq+Urdu&family=Noto+Sans+Arabic:wght@300&family=Noto+Serif&family=Oswald:wght@300&family=Oxygen:wght@300&family=Pacifico&family=Patua+One&family=Permanent+Marker&family=Playfair+Display&family=Poppins:wght@300&family=Prompt:wght@300&family=Qahiri&family=Questrial&family=Quicksand:wght@300&family=Raleway:wght@300&family=Readex+Pro:wght@300&family=Reem+Kufi&family=Reem+Kufi+Fun&family=Reem+Kufi+Ink&family=Righteous&family=Roboto+Mono:wght@300&family=Roboto+Slab:wght@300&family=Satisfy&family=Scheherazade+New&family=Schibsted+Grotesk&family=Sedgwick+Ave+Display&family=Sigmar&family=Signika+Negative:wght@300&family=Source+Code+Pro:wght@300;400&family=Source+Serif+Pro:wght@300&family=Space+Mono&family=Tajawal:wght@300&family=Teko:wght@300&family=Ubuntu:wght@300&family=Vibes&family=Vina+Sans&family=Yanone+Kaffeesatz:wght@300;400&family=Yellowtail&family=Ysabeau:wght@300&display=swap');\\r\\n\\r\\n:root {\\r\\n /* color-variables */\\r\\n --cbmis-blue: #1769aa;\\r\\n --cbmis-indigo: #6610f2;\\r\\n --cbmis-purple: #6f42c1;\\r\\n --cbmis-pink: #e91e63;\\r\\n --cbmis-red: #dc3545;\\r\\n --cbmis-orange: #fd7e14;\\r\\n --cbmis-yellow: #ffcc00;\\r\\n --cbmis-green: #198754;\\r\\n --cbmis-teal: #20c997;\\r\\n --cbmis-cyan: #0dcaf0;\\r\\n --cbmis-white: #fff;\\r\\n --cbmis-gray-100: #f8f9fa;\\r\\n --cbmis-gray-200: #e9ecef;\\r\\n --cbmis-gray-300: #dee2e6;\\r\\n --cbmis-gray-400: #ced4da;\\r\\n --cbmis-gray-500: #adb5bd;\\r\\n --cbmis-gray-600: #6c757d;\\r\\n --cbmis-gray-700: #495057;\\r\\n --cbmis-gray-800: #343a40;\\r\\n --cbmis-gray-900: #212529;\\r\\n --cbmis-black: #000;\\r\\n --cbmis_disabled : #ced1d5;\\r\\n\\r\\n \\r\\n \\r\\n \\r\\n /* theme-color-variables */\\r\\n --cbmis-gray: var(--cbmis-gray-600);\\r\\n --cbmis-dark: var(--cbmis-gray-800);\\r\\n --cbmis-primary: var(--cbmis-blue);\\r\\n --cbmis-secondary: var(--cbmis-purple);\\r\\n --cbmis-success: var(--cbmis-green);\\r\\n --cbmis-info: var(--cbmis-cyan);\\r\\n --cbmis-warning: var(--cbmis-yellow);\\r\\n --cbmis-error: var(--cbmis-red);\\r\\n --cbmis-light: var(--cbmis-gray-100);\\r\\n \\r\\n /* color-variables-rgb */\\r\\n --cbmis-blue-rgb: 13, 109, 253;\\r\\n --cbmis-indigo-rgb: 102, 16, 242;\\r\\n --cbmis-purple-rgb: 111, 66, 193;\\r\\n --cbmis-pink-rgb: 214, 51, 132;\\r\\n --cbmis-red-rgb: 220, 53, 69;\\r\\n --cbmis-orange-rgb: 253, 126, 20;\\r\\n --cbmis-yellow-rgb: 255, 193, 7;\\r\\n --cbmis-green-rgb: 25, 135, 84;\\r\\n --cbmis-teal-rgb: 32, 201, 151;\\r\\n --cbmis-cyan-rgb: 13, 202, 240;\\r\\n \\r\\n --cbmis-primary-rgb: 13, 110, 253;\\r\\n --cbmis-secondary-rgb: 108, 117, 125;\\r\\n --cbmis-success-rgb: 25, 135, 84;\\r\\n --cbmis-info-rgb: 13, 202, 240;\\r\\n --cbmis-warning-rgb: 255, 193, 7;\\r\\n --cbmis-error-rgb: 220, 53, 69;\\r\\n --cbmis-light-rgb: 248, 249, 250;\\r\\n --cbmis-dark-rgb: 33, 37, 41;\\r\\n --cbmis-white-rgb: 255, 255, 255;\\r\\n --cbmis-black-rgb: 0, 0, 0;\\r\\n \\r\\n /* color contrast */\\r\\n --cbmis-min-contrast-ratio:4.5;\\r\\n --cbmis-color-contrast-dark:var(--cbmis-black);\\r\\n --cbmis-color-contrast-light:var(--cbmis-white);\\r\\n --cbmis-gradient: linear-gradient(180deg, rgba(255, 255, 255, 0.15), rgba(255, 255, 255, 0));\\r\\n \\r\\n /* ratio color */\\r\\n --cbmis-blue-100: rgba(var(--cbmis-blue-rgb), 10%);\\r\\n --cbmis-blue-200: rgba(var(--cbmis-blue-rgb), 20%);\\r\\n --cbmis-blue-300: rgba(var(--cbmis-blue-rgb), 30%);\\r\\n --cbmis-blue-400: rgba(var(--cbmis-blue-rgb), 40%);\\r\\n --cbmis-blue-500: rgba(var(--cbmis-blue-rgb), 50%);\\r\\n --cbmis-blue-600: rgba(var(--cbmis-blue-rgb), 60%);\\r\\n --cbmis-blue-700: rgba(var(--cbmis-blue-rgb), 70%);\\r\\n --cbmis-blue-800: rgba(var(--cbmis-blue-rgb), 80%);\\r\\n --cbmis-blue-900: rgba(var(--cbmis-blue-rgb), 90%);\\r\\n \\r\\n --cbmis-indigo-100: rgba(var(--cbmis-indigo-rgb), 10%);\\r\\n --cbmis-indigo-200: rgba(var(--cbmis-indigo-rgb), 20%);\\r\\n --cbmis-indigo-300: rgba(var(--cbmis-indigo-rgb), 30%);\\r\\n --cbmis-indigo-400: rgba(var(--cbmis-indigo-rgb), 40%);\\r\\n --cbmis-indigo-500: rgba(var(--cbmis-indigo-rgb), 50%);\\r\\n --cbmis-indigo-600: rgba(var(--cbmis-indigo-rgb), 60%);\\r\\n --cbmis-indigo-700: rgba(var(--cbmis-indigo-rgb), 70%);\\r\\n --cbmis-indigo-800: rgba(var(--cbmis-indigo-rgb), 80%);\\r\\n --cbmis-indigo-900: rgba(var(--cbmis-indigo-rgb), 90%);\\r\\n \\r\\n --cbmis-purple-100: rgba(var(--cbmis-purple-rgb), 10%);\\r\\n --cbmis-purple-200: rgba(var(--cbmis-purple-rgb), 20%);\\r\\n --cbmis-purple-300: rgba(var(--cbmis-purple-rgb), 30%);\\r\\n --cbmis-purple-400: rgba(var(--cbmis-purple-rgb), 40%);\\r\\n --cbmis-purple-500: rgba(var(--cbmis-purple-rgb), 50%);\\r\\n --cbmis-purple-600: rgba(var(--cbmis-purple-rgb), 60%);\\r\\n --cbmis-purple-700: rgba(var(--cbmis-purple-rgb), 70%);\\r\\n --cbmis-purple-800: rgba(var(--cbmis-purple-rgb), 80%);\\r\\n --cbmis-purple-900: rgba(var(--cbmis-purple-rgb), 90%);\\r\\n \\r\\n --cbmis-pink-100: rgba(var(--cbmis-pink-rgb), 10%);\\r\\n --cbmis-pink-200: rgba(var(--cbmis-pink-rgb), 20%);\\r\\n --cbmis-pink-300: rgba(var(--cbmis-pink-rgb), 30%);\\r\\n --cbmis-pink-400: rgba(var(--cbmis-pink-rgb), 40%);\\r\\n --cbmis-pink-500: rgba(var(--cbmis-pink-rgb), 50%);\\r\\n --cbmis-pink-600: rgba(var(--cbmis-pink-rgb), 60%);\\r\\n --cbmis-pink-700: rgba(var(--cbmis-pink-rgb), 70%);\\r\\n --cbmis-pink-800: rgba(var(--cbmis-pink-rgb), 80%);\\r\\n --cbmis-pink-900: rgba(var(--cbmis-pink-rgb), 90%);\\r\\n \\r\\n --cbmis-red-100: rgba(var(--cbmis-red-rgb), 10%);\\r\\n --cbmis-red-200: rgba(var(--cbmis-red-rgb), 20%);\\r\\n --cbmis-red-300: rgba(var(--cbmis-red-rgb), 30%);\\r\\n --cbmis-red-400: rgba(var(--cbmis-red-rgb), 40%);\\r\\n --cbmis-red-500: rgba(var(--cbmis-red-rgb), 50%);\\r\\n --cbmis-red-600: rgba(var(--cbmis-red-rgb), 60%);\\r\\n --cbmis-red-700: rgba(var(--cbmis-red-rgb), 70%);\\r\\n --cbmis-red-800: rgba(var(--cbmis-red-rgb), 80%);\\r\\n --cbmis-red-900: rgba(var(--cbmis-red-rgb), 90%);\\r\\n \\r\\n --cbmis-orange-100: rgba(var(--cbmis-orange-rgb), 10%);\\r\\n --cbmis-orange-200: rgba(var(--cbmis-orange-rgb), 20%);\\r\\n --cbmis-orange-300: rgba(var(--cbmis-orange-rgb), 30%);\\r\\n --cbmis-orange-400: rgba(var(--cbmis-orange-rgb), 40%);\\r\\n --cbmis-orange-500: rgba(var(--cbmis-orange-rgb), 50%);\\r\\n --cbmis-orange-600: rgba(var(--cbmis-orange-rgb), 60%);\\r\\n --cbmis-orange-700: rgba(var(--cbmis-orange-rgb), 70%);\\r\\n --cbmis-orange-800: rgba(var(--cbmis-orange-rgb), 80%);\\r\\n --cbmis-orange-900: rgba(var(--cbmis-orange-rgb), 90%);\\r\\n \\r\\n --cbmis-yellow-100: rgba(var(--cbmis-yellow-rgb), 10%);\\r\\n --cbmis-yellow-200: rgba(var(--cbmis-yellow-rgb), 20%);\\r\\n --cbmis-yellow-300: rgba(var(--cbmis-yellow-rgb), 30%);\\r\\n --cbmis-yellow-400: rgba(var(--cbmis-yellow-rgb), 40%);\\r\\n --cbmis-yellow-500: rgba(var(--cbmis-yellow-rgb), 50%);\\r\\n --cbmis-yellow-600: rgba(var(--cbmis-yellow-rgb), 60%);\\r\\n --cbmis-yellow-700: rgba(var(--cbmis-yellow-rgb), 70%);\\r\\n --cbmis-yellow-800: rgba(var(--cbmis-yellow-rgb), 80%);\\r\\n --cbmis-yellow-900: rgba(var(--cbmis-yellow-rgb), 90%);\\r\\n \\r\\n --cbmis-green-100: rgba(var(--cbmis-green-rgb), 10%);\\r\\n --cbmis-green-200: rgba(var(--cbmis-green-rgb), 20%);\\r\\n --cbmis-green-300: rgba(var(--cbmis-green-rgb), 30%);\\r\\n --cbmis-green-400: rgba(var(--cbmis-green-rgb), 40%);\\r\\n --cbmis-green-500: rgba(var(--cbmis-green-rgb), 50%);\\r\\n --cbmis-green-600: rgba(var(--cbmis-green-rgb), 60%);\\r\\n --cbmis-green-700: rgba(var(--cbmis-green-rgb), 70%);\\r\\n --cbmis-green-800: rgba(var(--cbmis-green-rgb), 80%);\\r\\n --cbmis-green-900: rgba(var(--cbmis-green-rgb), 90%);\\r\\n \\r\\n --cbmis-teal-100: rgba(var(--cbmis-teal-rgb), 10%);\\r\\n --cbmis-teal-200: rgba(var(--cbmis-teal-rgb), 20%);\\r\\n --cbmis-teal-300: rgba(var(--cbmis-teal-rgb), 30%);\\r\\n --cbmis-teal-400: rgba(var(--cbmis-teal-rgb), 40%);\\r\\n --cbmis-teal-500: rgba(var(--cbmis-teal-rgb), 50%);\\r\\n --cbmis-teal-600: rgba(var(--cbmis-teal-rgb), 60%);\\r\\n --cbmis-teal-700: rgba(var(--cbmis-teal-rgb), 70%);\\r\\n --cbmis-teal-800: rgba(var(--cbmis-teal-rgb), 80%);\\r\\n --cbmis-teal-900: rgba(var(--cbmis-teal-rgb), 90%);\\r\\n \\r\\n --cbmis-cyan-100: rgba(var(--cbmis-cyan-rgb), 10%);\\r\\n --cbmis-cyan-200: rgba(var(--cbmis-cyan-rgb), 20%);\\r\\n --cbmis-cyan-300: rgba(var(--cbmis-cyan-rgb), 30%);\\r\\n --cbmis-cyan-400: rgba(var(--cbmis-cyan-rgb), 40%);\\r\\n --cbmis-cyan-500: rgba(var(--cbmis-cyan-rgb), 50%);\\r\\n --cbmis-cyan-600: rgba(var(--cbmis-cyan-rgb), 60%);\\r\\n --cbmis-cyan-700: rgba(var(--cbmis-cyan-rgb), 70%);\\r\\n --cbmis-cyan-800: rgba(var(--cbmis-cyan-rgb), 80%);\\r\\n --cbmis-cyan-900: rgba(var(--cbmis-cyan-rgb), 90%); \\r\\n \\r\\n --cbmis-primary-100: rgba(var(--cbmis-primary-rgb), 10%);\\r\\n --cbmis-primary-200: rgba(var(--cbmis-primary-rgb), 20%);\\r\\n --cbmis-primary-300: rgba(var(--cbmis-primary-rgb), 30%);\\r\\n --cbmis-primary-400: rgba(var(--cbmis-primary-rgb), 40%);\\r\\n --cbmis-primary-500: rgba(var(--cbmis-primary-rgb), 50%);\\r\\n --cbmis-primary-600: rgba(var(--cbmis-primary-rgb), 60%);\\r\\n --cbmis-primary-700: rgba(var(--cbmis-primary-rgb), 70%);\\r\\n --cbmis-primary-800: rgba(var(--cbmis-primary-rgb), 80%);\\r\\n --cbmis-primary-900: rgba(var(--cbmis-primary-rgb), 90%); \\r\\n \\r\\n --cbmis-secondary-100: rgba(var(--cbmis-secondary-rgb), 10%);\\r\\n --cbmis-secondary-200: rgba(var(--cbmis-secondary-rgb), 20%);\\r\\n --cbmis-secondary-300: rgba(var(--cbmis-secondary-rgb), 30%);\\r\\n --cbmis-secondary-400: rgba(var(--cbmis-secondary-rgb), 40%);\\r\\n --cbmis-secondary-500: rgba(var(--cbmis-secondary-rgb), 50%);\\r\\n --cbmis-secondary-600: rgba(var(--cbmis-secondary-rgb), 60%);\\r\\n --cbmis-secondary-700: rgba(var(--cbmis-secondary-rgb), 70%);\\r\\n --cbmis-secondary-800: rgba(var(--cbmis-secondary-rgb), 80%);\\r\\n --cbmis-secondary-900: rgba(var(--cbmis-secondary-rgb), 90%);\\r\\n \\r\\n --cbmis-success-100: rgba(var(--cbmis-success-rgb), 10%);\\r\\n --cbmis-success-200: rgba(var(--cbmis-success-rgb), 20%);\\r\\n --cbmis-success-300: rgba(var(--cbmis-success-rgb), 30%);\\r\\n --cbmis-success-400: rgba(var(--cbmis-success-rgb), 40%);\\r\\n --cbmis-success-500: rgba(var(--cbmis-success-rgb), 50%);\\r\\n --cbmis-success-600: rgba(var(--cbmis-success-rgb), 60%);\\r\\n --cbmis-success-700: rgba(var(--cbmis-success-rgb), 70%);\\r\\n --cbmis-success-800: rgba(var(--cbmis-success-rgb), 80%);\\r\\n --cbmis-success-900: rgba(var(--cbmis-success-rgb), 90%);\\r\\n \\r\\n --cbmis-info-100: rgba(var(--cbmis-info-rgb), 10%);\\r\\n --cbmis-info-200: rgba(var(--cbmis-info-rgb), 20%);\\r\\n --cbmis-info-300: rgba(var(--cbmis-info-rgb), 30%);\\r\\n --cbmis-info-400: rgba(var(--cbmis-info-rgb), 40%);\\r\\n --cbmis-info-500: rgba(var(--cbmis-info-rgb), 50%);\\r\\n --cbmis-info-600: rgba(var(--cbmis-info-rgb), 60%);\\r\\n --cbmis-info-700: rgba(var(--cbmis-info-rgb), 70%);\\r\\n --cbmis-info-800: rgba(var(--cbmis-info-rgb), 80%);\\r\\n --cbmis-info-900: rgba(var(--cbmis-info-rgb), 90%); \\r\\n \\r\\n --cbmis-warning-100: rgba(var(--cbmis-warning-rgb), 10%);\\r\\n --cbmis-warning-200: rgba(var(--cbmis-warning-rgb), 20%);\\r\\n --cbmis-warning-300: rgba(var(--cbmis-warning-rgb), 30%);\\r\\n --cbmis-warning-400: rgba(var(--cbmis-warning-rgb), 40%);\\r\\n --cbmis-warning-500: rgba(var(--cbmis-warning-rgb), 50%);\\r\\n --cbmis-warning-600: rgba(var(--cbmis-warning-rgb), 60%);\\r\\n --cbmis-warning-700: rgba(var(--cbmis-warning-rgb), 70%);\\r\\n --cbmis-warning-800: rgba(var(--cbmis-warning-rgb), 80%);\\r\\n --cbmis-warning-900: rgba(var(--cbmis-warning-rgb), 90%); \\r\\n \\r\\n --cbmis-error-100: rgba(var(--cbmis-error-rgb), 10%);\\r\\n --cbmis-error-200: rgba(var(--cbmis-error-rgb), 20%);\\r\\n --cbmis-error-300: rgba(var(--cbmis-error-rgb), 30%);\\r\\n --cbmis-error-400: rgba(var(--cbmis-error-rgb), 40%);\\r\\n --cbmis-error-500: rgba(var(--cbmis-error-rgb), 50%);\\r\\n --cbmis-error-600: rgba(var(--cbmis-error-rgb), 60%);\\r\\n --cbmis-error-700: rgba(var(--cbmis-error-rgb), 70%);\\r\\n --cbmis-error-800: rgba(var(--cbmis-error-rgb), 80%);\\r\\n --cbmis-error-900: rgba(var(--cbmis-error-rgb), 90%); \\r\\n \\r\\n --cbmis-light-100: rgba(var(--cbmis-light-rgb), 10%);\\r\\n --cbmis-light-200: rgba(var(--cbmis-light-rgb), 20%);\\r\\n --cbmis-light-300: rgba(var(--cbmis-light-rgb), 30%);\\r\\n --cbmis-light-400: rgba(var(--cbmis-light-rgb), 40%);\\r\\n --cbmis-light-500: rgba(var(--cbmis-light-rgb), 50%);\\r\\n --cbmis-light-600: rgba(var(--cbmis-light-rgb), 60%);\\r\\n --cbmis-light-700: rgba(var(--cbmis-light-rgb), 70%);\\r\\n --cbmis-light-800: rgba(var(--cbmis-light-rgb), 80%);\\r\\n --cbmis-light-900: rgba(var(--cbmis-light-rgb), 90%); \\r\\n \\r\\n --cbmis-dark-100: rgba(var(--cbmis-dark-rgb), 10%);\\r\\n --cbmis-dark-200: rgba(var(--cbmis-dark-rgb), 20%);\\r\\n --cbmis-dark-300: rgba(var(--cbmis-dark-rgb), 30%);\\r\\n --cbmis-dark-400: rgba(var(--cbmis-dark-rgb), 40%);\\r\\n --cbmis-dark-500: rgba(var(--cbmis-dark-rgb), 50%);\\r\\n --cbmis-dark-600: rgba(var(--cbmis-dark-rgb), 60%);\\r\\n --cbmis-dark-700: rgba(var(--cbmis-dark-rgb), 70%);\\r\\n --cbmis-dark-800: rgba(var(--cbmis-dark-rgb), 80%);\\r\\n --cbmis-dark-900: rgba(var(--cbmis-dark-rgb), 90%); \\r\\n \\r\\n --cbmis-white-100: rgba(var(--cbmis-white-rgb), 10%);\\r\\n --cbmis-white-200: rgba(var(--cbmis-white-rgb), 20%);\\r\\n --cbmis-white-300: rgba(var(--cbmis-white-rgb), 30%);\\r\\n --cbmis-white-400: rgba(var(--cbmis-white-rgb), 40%);\\r\\n --cbmis-white-500: rgba(var(--cbmis-white-rgb), 50%);\\r\\n --cbmis-white-600: rgba(var(--cbmis-white-rgb), 60%);\\r\\n --cbmis-white-700: rgba(var(--cbmis-white-rgb), 70%);\\r\\n --cbmis-white-800: rgba(var(--cbmis-white-rgb), 80%);\\r\\n --cbmis-white-900: rgba(var(--cbmis-white-rgb), 90%); \\r\\n \\r\\n --cbmis-black-100: rgba(var(--cbmis-black-rgb), 10%);\\r\\n --cbmis-black-200: rgba(var(--cbmis-black-rgb), 20%);\\r\\n --cbmis-black-300: rgba(var(--cbmis-black-rgb), 30%);\\r\\n --cbmis-black-400: rgba(var(--cbmis-black-rgb), 40%);\\r\\n --cbmis-black-500: rgba(var(--cbmis-black-rgb), 50%);\\r\\n --cbmis-black-600: rgba(var(--cbmis-black-rgb), 60%);\\r\\n --cbmis-black-700: rgba(var(--cbmis-black-rgb), 70%);\\r\\n --cbmis-black-800: rgba(var(--cbmis-black-rgb), 80%);\\r\\n --cbmis-black-900: rgba(var(--cbmis-black-rgb), 90%); \\r\\n \\r\\n --cbmis-input-color:var(--cbmis-gray-600);\\r\\n --cbmis-input-color-focus:var(--cbmis-primary);\\r\\n \\r\\n /* body values */\\r\\n --cbmis-body-font-family: var(--cbmis-font-sans-serif);\\r\\n --cbmis-body-font-size: 1rem;\\r\\n --cbmis-body-font-weight: 500;\\r\\n --cbmis-body-line-height: 1.5;\\r\\n --cbmis-body-color-dark: var(--cbmis-dark-700);\\r\\n --cbmis-body-color-gray: var(--cbmis-gray-700);\\r\\n --cbmis-body-color: var(--cbmis-gray-700);\\r\\n --cbmis-body-color-light: var(--cbmis-gray-200);\\r\\n --cbmis-body-bg: var(--cbmis-white);\\r\\n --cbmis-body-text-align:none;\\r\\n \\r\\n /* links Style anchor elements */\\r\\n --cbmis-link-color:var(--cbmis-primary);\\r\\n --cbmis-link-decoration:underline;\\r\\n --cbmis-link-hover-color: var(--cbmis-primary-200);\\r\\n --cbmis-link-hover-decoration: none;\\r\\n \\r\\n /* border-variables */\\r\\n --cbmis-border-width-1: 1px;\\r\\n --cbmis-border-width-2: 2px;\\r\\n --cbmis-border-width-3: 3px;\\r\\n --cbmis-border-width-4: 4px;\\r\\n --cbmis-border-width-5: 5px;\\r\\n --cbmis-border-color:var(--cbmis-gray-300);\\r\\n --cbmis-border-radius:.5rem;\\r\\n --cbmis-border-radius-sm:.2rem;\\r\\n --cbmis-border-radius-md:.4rem;\\r\\n --cbmis-border-radius-lg:.8rem;\\r\\n --cbmis-border-radius-xl:1rem;\\r\\n --cbmis-border-radius-pill:100%;\\r\\n \\r\\n /* box-shadow-variables */\\r\\n --cbmis-box-shadow: 1px 4px 2px -2px var(--cbmis-black-200), 1px 3px 3px 1px var(--cbmis-black-200), 1px 2px 6px 1px var(--cbmis-black-200);\\r\\n /* --cbmis-box-shadow-1: 0px 3px 1px -2px var(--cbmis-black-200), 0px 2px 2px 0px var(--cbmis-black-200), 0px 1px 5px 0px var(--cbmis-black-100); */\\r\\n --cbmis-box-shadow-1: rgb(0 0 0 / 20%) 0px 2px 1px -1px, rgb(0 0 0 / 14%) 0px 1px 1px 0px, rgb(0 0 0 / 12%) 0px 1px 3px 0px;\\r\\n --cbmis-box-shadow-2: var(--cbmis-border-color) 0px 8px 24px;\\r\\n --cbmis-box-shadow-3: var(--cbmis-black-300) 0px 5px 15px ;\\r\\n --cbmis-box-shadow-4: var(--cbmis-black-200) 0px 1px 4px, var(--cbmis-border-color) 0px 0px 0px 3px;;\\r\\n --cbmis-box-shadow-5: var(--cbmis-black-200) 0px 54px 55px, var(--cbmis-black-100) 0px -12px 30px, var(--cbmis-black-100) 0px 4px 6px, var(--cbmis-black-200) 0px 12px 13px, var(--cbmis-black-100) 0px -3px 5px;\\r\\n --cbmis-box-shadow-inset-1: var(--cbmis-border-color) 0px 50px 100px -20px, var(--cbmis-black-300) 0px 30px 60px -30px, var(--cbmis-dark-200) 0px -2px 6px 0px inset;\\r\\n --cbmis-box-shadow-inset-2: var(--cbmis-border-color) 0px 30px 60px -12px inset, var(--cbmis-black-300) 0px 18px 36px -18px inset;\\r\\n --cbmis-box-shadow-inset-3: var(--cbmis-border-color) 3px 3px 6px 0px inset, var(--cbmis-black-500) -3px -3px 6px 1px inset;\\r\\n --cbmis-box-shadow-inset-4: var(--cbmis-black-200) 0px -23px 25px 0px inset, var(--cbmis-black-100) 0px -36px 30px 0px inset, var(--cbmis-black-100) 0px -79px 40px 0px inset, var(--cbmis-black-100) 0px 2px 1px, var(--cbmis-black-100) 0px 4px 2px, var(--cbmis-black-100) 0px 8px 4px, var(--cbmis-black-100) 0px 16px 8px, var(--cbmis-black-200) 0px 32px 16px;\\r\\n --cbmis-box-shadow-inset-5: var(--cbmis-black-400) 0px 2px 4px, var(--cbmis-black-300) 0px 7px 13px -3px, var(--cbmis-black-200) 0px -3px 0px inset;\\r\\n \\r\\n /*box-size-variable */\\r\\n --cbmis-border-box-sizing: border-box;\\r\\n --cbmis-content-box-sizing: content-box;\\r\\n --cbmis-inherit-box-sizing: inherit;\\r\\n \\r\\n /*spacer-variables */\\r\\n --cbmis-spacer: 1rem;\\r\\n --cbmis-spacer-0: 0;\\r\\n --cbmis-spacer-1: .25rem;\\r\\n --cbmis-spacer-2: .5rem;\\r\\n --cbmis-spacer-3: var(--cbmis-spacer);\\r\\n --cbmis-spacer-4: 1.5rem;\\r\\n --cbmis-spacer-5: 3rem;\\r\\n \\r\\n /* Font */\\r\\n --cbmis-font-family-sans-serif: system-ui, -apple-system, \\\"Segoe UI\\\", Roboto, \\\"Helvetica Neue\\\", Arial, \\\"Noto Sans\\\", \\\"Liberation Sans\\\", sans-serif, \\\"Apple Color Emoji\\\", \\\"Segoe UI Emoji\\\", \\\"Segoe UI Symbol\\\", \\\"Noto Color Emoji\\\" ;\\r\\n --cbmis-font-family-monospace: SFMono-Regular, Menlo, Monaco, Consolas, \\\"Liberation Mono\\\", \\\"Courier New\\\", monospace ;\\r\\n --cbmis-font-family-Roboto:\\\"Roboto\\\", \\\"Helvetica\\\", \\\"Arial\\\", sans-serif;\\r\\n \\r\\n --cbmis-font-size: 1rem ; \\r\\n --cbmis-font-size-xs: .75rem ;\\r\\n --cbmis-font-size-sm: 1rem ;\\r\\n --cbmis-font-size-md: 1.25rem ;\\r\\n --cbmis-font-size-lg: 1.5rem;\\r\\n --cbmis-font-size-xl: 2rem;\\r\\n --cbmis-font-size-icon :1.20rem;\\r\\n \\r\\n --cbmis-font-weight-lighter: lighter;\\r\\n --cbmis-font-weight-light: 300;\\r\\n --cbmis-font-weight-normal: 400;\\r\\n --cbmis-font-weight-bold: 600;\\r\\n --cbmis-font-weight-bolder: bolder;\\r\\n \\r\\n --cbmis-line-height: 1.5;\\r\\n --cbmis-line-height-sm: 1.25;\\r\\n --cbmis-line-height-lg: 2;\\r\\n \\r\\n --cbmis-h1-font-size: 4rem;\\r\\n --cbmis-h2-font-size: 3.5rem;\\r\\n --cbmis-h3-font-size: 3rem;\\r\\n --cbmis-h4-font-size: 2rem;\\r\\n --cbmis-h5-font-size: 1.5rem;\\r\\n --cbmis-h6-font-size: 1.25rem;\\r\\n --cbmis-subtitle1-font-size: var(--cbmis-font-size);\\r\\n --cbmis-subtitle2-font-size: 0.875rem;\\r\\n --cbmis-body1-font-size: var(--cbmis-font-size);\\r\\n --cbmis-body2-font-size: 0.875rem;\\r\\n --cbmis-caption-font-size:0.75rem;\\r\\n --cbmis-overline-font-size:0.75rem;\\r\\n \\r\\n --cbmis-font-size-1:var(--cbmis-h1-font-size);\\r\\n --cbmis-font-size-2:var(--cbmis-h2-font-size);\\r\\n --cbmis-font-size-3:var(--cbmis-h3-font-size);\\r\\n --cbmis-font-size-4:var(--cbmis-h4-font-size);\\r\\n --cbmis-font-size-5:var(--cbmis-h5-font-size);\\r\\n --cbmis-font-size-6:var(--cbmis-h6-font-size);\\r\\n \\r\\n --cbmis-width-xs: 420px;\\r\\n --cbmis-width-sm: 576px;\\r\\n --cbmis-width-md: 640px;\\r\\n --cbmis-width-lg: 920px;\\r\\n --cbmis-width-xl: 1200px;\\r\\n --cbmis-width-fluid: 100%;\\r\\n --cbmis-width-half:50%;\\r\\n \\r\\n --cbmis-width-item-xs: var(--cbmis-spacer-4);\\r\\n --cbmis-width-item-sm: var(--cbmis-spacer-5);\\r\\n --cbmis-width-item-md: 3.7rem;\\r\\n --cbmis-width-item-lg: 5rem;\\r\\n --cbmis-width-item-xl: 6rem;\\r\\n --cbmis-width-item-fluid: 100%;\\r\\n --cbmis-width-item-half:50%;\\r\\n \\r\\n --cbmis-z-index--1:-1;\\r\\n --cbmis-z-index-0:0;\\r\\n --cbmis-z-index-1:1;\\r\\n --cbmis-z-index-2:2;\\r\\n --cbmis-z-index-3:3;\\r\\n --cbmis-z-index-10:10;\\r\\n --cbmis-z-index-100:100;\\r\\n --cbmis-z-index-101:101;\\r\\n --cbmis-z-index-102:102;\\r\\n --cbmis-z-index-103:103;\\r\\n --cbmis-z-index-104:104;\\r\\n --cbmis-z-index-105:105;\\r\\n --cbmis-z-index-106:106;\\r\\n --cbmis-z-index-107:107;\\r\\n --cbmis-z-index-108:108;\\r\\n --cbmis-z-index-109:109;\\r\\n --cbmis-z-index-110:110;\\r\\n --cbmis-z-index-996:996;\\r\\n --cbmis-z-index-997:997;\\r\\n --cbmis-z-index-998:998;\\r\\n --cbmis-z-index-999:999;\\r\\n --cbmis-z-index-1000:1000;\\r\\n --cbmis-z-index-1001:1001;\\r\\n --cbmis-z-index-100000000:100000000; /*judtCamera*/\\r\\n --cbmis-z-index-100000001:100000001;\\r\\n --cbmis-z-index-100000002:100000002;\\r\\n --cbmis-z-index-100000003:100000003; /*just loader*/\\r\\n\\r\\n --cbmis-z-index-loader:1000000000; \\r\\n \\r\\n \\r\\n /* --cbmis-clip-path-circle: circle(48% at 50% 50%); */\\r\\n --cbmis-clip-path-oval: ellipse(30% 40% at 50% 50%);\\r\\n --cbmis-clip-path-triangle: polygon(50% 0%, 0% 100%, 100% 100%);\\r\\n --cbmis-clip-path-pentagon: polygon(50% 0%, 100% 38%, 82% 100%, 18% 100%, 0% 38%); \\r\\n --cbmis-clip-path-hexagon: polygon(25% 0%, 75% 0%, 100% 50%, 75% 100%, 25% 100%, 0% 50%);\\r\\n --cbmis-clip-path-heptagon: polygon(50% 0%, 90% 20%, 100% 60%, 75% 100%, 25% 100%, 0% 60%, 10% 20%);\\r\\n --cbmis-clip-path-octagon: polygon(30% 0%, 70% 0%, 100% 30%, 100% 70%, 70% 100%, 30% 100%, 0% 70%, 0% 30%); \\r\\n --cbmis-clip-path-star: polygon(50% 0%, 61% 35%, 98% 35%, 68% 57%, 79% 91%, 50% 70%, 21% 91%, 32% 57%, 2% 35%, 39% 35%); \\r\\n --cbmis-clip-path-top-chevron: polygon(0 100%, 50% 75%, 100% 100%, 100% 25%, 50% 0, 0 25%); \\r\\n --cbmis-clip-path-left-chevron: polygon(100% 0%, 75% 50%, 100% 100%, 25% 100%, 0% 50%, 25% 0%); \\r\\n --cbmis-clip-path-right-chevron: polygon(75% 0%, 100% 50%, 75% 100%, 0% 100%, 25% 50%, 0% 0%); \\r\\n --cbmis-clip-path-bottom-chevron: polygon(0 0, 50% 25%, 100% 0, 100% 75%, 50% 100%, 0 75%); \\r\\n \\r\\n /*margin*/\\r\\n --cbmis-margin-0:0;\\r\\n --cbmis-margin-1:4px;\\r\\n --cbmis-margin-2:8px;\\r\\n --cbmis-margin-3:12px;\\r\\n --cbmis-margin-4:16px;\\r\\n --cbmis-margin-5:20px;\\r\\n --cbmis-margin-6:24px;\\r\\n --cbmis-margin-7:28px;\\r\\n --cbmis-margin-8:32px;\\r\\n --cbmis-margin-9:36px;\\r\\n --cbmis-margin-10:40px;\\r\\n \\r\\n /*padding*/\\r\\n --cbmis-padding-0:0;\\r\\n --cbmis-padding-1:4px;\\r\\n --cbmis-padding-2:8px;\\r\\n --cbmis-padding-3:12px;\\r\\n --cbmis-padding-4:16px;\\r\\n --cbmis-padding-5:20px;\\r\\n --cbmis-padding-6:24px;\\r\\n --cbmis-padding-7:28px;\\r\\n --cbmis-padding-8:32px;\\r\\n --cbmis-padding-9:36px;\\r\\n --cbmis-padding-10:40px;\\r\\n}\\r\\n\"],\"sourceRoot\":\"\"}]);\n// Exports\nexport default ___CSS_LOADER_EXPORT___;\n","\n import API from \"!../../../../node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js\";\n import domAPI from \"!../../../../node_modules/style-loader/dist/runtime/styleDomAPI.js\";\n import insertFn from \"!../../../../node_modules/style-loader/dist/runtime/insertBySelector.js\";\n import setAttributes from \"!../../../../node_modules/style-loader/dist/runtime/setAttributesWithoutAttributes.js\";\n import insertStyleElement from \"!../../../../node_modules/style-loader/dist/runtime/insertStyleElement.js\";\n import styleTagTransformFn from \"!../../../../node_modules/style-loader/dist/runtime/styleTagTransform.js\";\n import content, * as namedExport from \"!!../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[1].use[1]!./main.css\";\n \n \n\nvar options = {};\n\noptions.styleTagTransform = styleTagTransformFn;\noptions.setAttributes = setAttributes;\noptions.insert = insertFn.bind(null, \"head\");\noptions.domAPI = domAPI;\noptions.insertStyleElement = insertStyleElement;\n\nvar update = API(content, options);\n\n\n\nexport * from \"!!../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[1].use[1]!./main.css\";\n export default content && content.locals ? content.locals : undefined;\n","\n import API from \"!../../../../node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js\";\n import domAPI from \"!../../../../node_modules/style-loader/dist/runtime/styleDomAPI.js\";\n import insertFn from \"!../../../../node_modules/style-loader/dist/runtime/insertBySelector.js\";\n import setAttributes from \"!../../../../node_modules/style-loader/dist/runtime/setAttributesWithoutAttributes.js\";\n import insertStyleElement from \"!../../../../node_modules/style-loader/dist/runtime/insertStyleElement.js\";\n import styleTagTransformFn from \"!../../../../node_modules/style-loader/dist/runtime/styleTagTransform.js\";\n import content, * as namedExport from \"!!../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[1].use[1]!./themes.css\";\n \n \n\nvar options = {};\n\noptions.styleTagTransform = styleTagTransformFn;\noptions.setAttributes = setAttributes;\noptions.insert = insertFn.bind(null, \"head\");\noptions.domAPI = domAPI;\noptions.insertStyleElement = insertStyleElement;\n\nvar update = API(content, options);\n\n\n\nexport * from \"!!../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[1].use[1]!./themes.css\";\n export default content && content.locals ? content.locals : undefined;\n","\n import API from \"!../../../../node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js\";\n import domAPI from \"!../../../../node_modules/style-loader/dist/runtime/styleDomAPI.js\";\n import insertFn from \"!../../../../node_modules/style-loader/dist/runtime/insertBySelector.js\";\n import setAttributes from \"!../../../../node_modules/style-loader/dist/runtime/setAttributesWithoutAttributes.js\";\n import insertStyleElement from \"!../../../../node_modules/style-loader/dist/runtime/insertStyleElement.js\";\n import styleTagTransformFn from \"!../../../../node_modules/style-loader/dist/runtime/styleTagTransform.js\";\n import content, * as namedExport from \"!!../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[1].use[1]!./dataCbmisDefault.css\";\n \n \n\nvar options = {};\n\noptions.styleTagTransform = styleTagTransformFn;\noptions.setAttributes = setAttributes;\noptions.insert = insertFn.bind(null, \"head\");\noptions.domAPI = domAPI;\noptions.insertStyleElement = insertStyleElement;\n\nvar update = API(content, options);\n\n\n\nexport * from \"!!../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[1].use[1]!./dataCbmisDefault.css\";\n export default content && content.locals ? content.locals : undefined;\n","\n import API from \"!../../../../node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js\";\n import domAPI from \"!../../../../node_modules/style-loader/dist/runtime/styleDomAPI.js\";\n import insertFn from \"!../../../../node_modules/style-loader/dist/runtime/insertBySelector.js\";\n import setAttributes from \"!../../../../node_modules/style-loader/dist/runtime/setAttributesWithoutAttributes.js\";\n import insertStyleElement from \"!../../../../node_modules/style-loader/dist/runtime/insertStyleElement.js\";\n import styleTagTransformFn from \"!../../../../node_modules/style-loader/dist/runtime/styleTagTransform.js\";\n import content, * as namedExport from \"!!../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[1].use[1]!./dataCbmisSx.css\";\n \n \n\nvar options = {};\n\noptions.styleTagTransform = styleTagTransformFn;\noptions.setAttributes = setAttributes;\noptions.insert = insertFn.bind(null, \"head\");\noptions.domAPI = domAPI;\noptions.insertStyleElement = insertStyleElement;\n\nvar update = API(content, options);\n\n\n\nexport * from \"!!../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[1].use[1]!./dataCbmisSx.css\";\n export default content && content.locals ? content.locals : undefined;\n","\n import API from \"!../../../../node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js\";\n import domAPI from \"!../../../../node_modules/style-loader/dist/runtime/styleDomAPI.js\";\n import insertFn from \"!../../../../node_modules/style-loader/dist/runtime/insertBySelector.js\";\n import setAttributes from \"!../../../../node_modules/style-loader/dist/runtime/setAttributesWithoutAttributes.js\";\n import insertStyleElement from \"!../../../../node_modules/style-loader/dist/runtime/insertStyleElement.js\";\n import styleTagTransformFn from \"!../../../../node_modules/style-loader/dist/runtime/styleTagTransform.js\";\n import content, * as namedExport from \"!!../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[1].use[1]!./dataClientStyle.css\";\n \n \n\nvar options = {};\n\noptions.styleTagTransform = styleTagTransformFn;\noptions.setAttributes = setAttributes;\noptions.insert = insertFn.bind(null, \"head\");\noptions.domAPI = domAPI;\noptions.insertStyleElement = insertStyleElement;\n\nvar update = API(content, options);\n\n\n\nexport * from \"!!../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[1].use[1]!./dataClientStyle.css\";\n export default content && content.locals ? content.locals : undefined;\n","\"use client\";\r\n\r\nexport default function AppStyleConfig() {\r\n const objAppStyleConfig = {\r\n intStyleSheetDefaultIndex: null,\r\n intStyleSheetSxIndex: null,\r\n intStyleSheetClientIndex: null,\r\n objCssRuleCacheSX: new Map(),\r\n objCssRuleCacheDefault: new Map(),\r\n objCssRuleCacheClient: new Map(),\r\n };\r\n \r\n let blnFindDefault = false;\r\n let blnFindSx = false;\r\n let blnFindClient = false;\r\n\r\n let lstSheet = [];\r\n if (typeof document !== \"undefined\") {\r\n lstSheet = document?.styleSheets;\r\n }\r\n\r\n for (let i = lstSheet?.length - 1; i >= 0; i--) {\r\n const element = document.styleSheets[i];\r\n if (String(element?.cssRules[0]?.cssText).toLowerCase().replaceAll(\" \", \"\") === `:root{--data-cbmis:\"default-css\";}`) {\r\n objAppStyleConfig.intStyleSheetDefaultIndex = i;\r\n blnFindDefault = true;\r\n } else if (String(element?.cssRules[0]?.cssText).toLowerCase().replaceAll(\" \", \"\") === `:root{--data-cbmis:\"sx-css\";}`) {\r\n objAppStyleConfig.intStyleSheetSxIndex = i;\r\n blnFindSx = true;\r\n } else if (String(element?.cssRules[0]?.cssText).toLowerCase().replaceAll(\" \", \"\") === `:root{--data-cbmis:\"client-css\";}`) {\r\n objAppStyleConfig.intStyleSheetClientIndex = i;\r\n blnFindClient = true;\r\n }\r\n\r\n if (blnFindClient && blnFindDefault && blnFindSx) {\r\n break;\r\n }\r\n }\r\n\r\n return objAppStyleConfig;\r\n}\r\n\r\nexport const checkStyleSheetIndex = (appStyleConfig, blnIsDefaultStyle, blnCbmisStyle, indexStyle) => {\r\n const element = document.styleSheets[indexStyle];\r\n\r\n let blnIsExist = false;\r\n if (blnIsDefaultStyle && blnCbmisStyle && String(element?.cssRules?.[0]?.cssText).toLowerCase().replaceAll(\" \", \"\") === `:root{--data-cbmis:\"default-css\";}`) {\r\n blnIsExist = true;\r\n } else if (!blnIsDefaultStyle && blnCbmisStyle && String(element?.cssRules?.[0]?.cssText).toLowerCase().replaceAll(\" \", \"\") === `:root{--data-cbmis:\"sx-css\";}`) {\r\n blnIsExist = true;\r\n } else if (!blnCbmisStyle && String(element?.cssRules?.[0]?.cssText).toLowerCase().replaceAll(\" \", \"\") === `:root{--data-cbmis:\"client-css\";}`) {\r\n blnIsExist = true;\r\n }\r\n\r\n if (!blnIsExist) {\r\n let blnFindDefault = false;\r\n let blnFindSx = false;\r\n let blnFindClient = false;\r\n for (let i = document.styleSheets.length - 1; i >= 0; i--) {\r\n const element = document.styleSheets[i];\r\n if (String(element?.cssRules[0]?.cssText).toLowerCase().replaceAll(\" \", \"\") === `:root{--data-cbmis:\"default-css\";}`) {\r\n appStyleConfig.intStyleSheetDefaultIndex = i;\r\n blnFindDefault = true;\r\n } else if (String(element?.cssRules[0]?.cssText).toLowerCase().replaceAll(\" \", \"\") === `:root{--data-cbmis:\"sx-css\";}`) {\r\n appStyleConfig.intStyleSheetSxIndex = i;\r\n blnFindSx = true;\r\n } else if (String(element?.cssRules[0]?.cssText).toLowerCase().replaceAll(\" \", \"\") === `:root{--data-cbmis:\"client-css\";}`) {\r\n appStyleConfig.intStyleSheetClientIndex = i;\r\n blnFindClient = true;\r\n }\r\n\r\n if (!blnCbmisStyle && blnFindClient) {\r\n break;\r\n }\r\n if (blnCbmisStyle && blnFindDefault && blnFindSx) {\r\n break;\r\n }\r\n }\r\n }\r\n};\r\n\r\nexport function getCacheStyleSheetIndex(appStyleConfig, { blnIsDefaultStyle, blnCbmisStyle }) {\r\n const indexStyle =\r\n blnIsDefaultStyle && blnCbmisStyle\r\n ? appStyleConfig.intStyleSheetDefaultIndex\r\n : blnCbmisStyle\r\n ? appStyleConfig.intStyleSheetSxIndex\r\n : appStyleConfig.intStyleSheetClientIndex;\r\n checkStyleSheetIndex(appStyleConfig, blnIsDefaultStyle, blnCbmisStyle, indexStyle);\r\n\r\n return blnIsDefaultStyle && blnCbmisStyle\r\n ? appStyleConfig.intStyleSheetDefaultIndex\r\n : blnCbmisStyle\r\n ? appStyleConfig.intStyleSheetSxIndex\r\n : appStyleConfig.intStyleSheetClientIndex;\r\n}\r\n\r\nexport function getCacheStoreTrack(appStyleConfig, { blnIsDefaultStyle, blnCbmisStyle }) {\r\n return blnIsDefaultStyle && blnCbmisStyle\r\n ? appStyleConfig.objCssRuleCacheDefault\r\n : blnCbmisStyle\r\n ? appStyleConfig.objCssRuleCacheSX\r\n : appStyleConfig.objCssRuleCacheClient;\r\n}\r\n","\"use client\";\r\n\r\nimport { pkgConfigStyle } from \"..\";\r\n\r\nfunction murmurhash2_32_gc(str) {\r\n let l = str.length;\r\n let h = l;\r\n let i = 0;\r\n let k;\r\n\r\n while (l >= 4) {\r\n k = (str.charCodeAt(i) & 0xff) | ((str.charCodeAt(++i) & 0xff) << 8) | ((str.charCodeAt(++i) & 0xff) << 16) | ((str.charCodeAt(++i) & 0xff) << 24);\r\n\r\n k = (k & 0xffff) * 0x5bd1e995 + ((((k >>> 16) * 0x5bd1e995) & 0xffff) << 16);\r\n k ^= k >>> 24;\r\n k = (k & 0xffff) * 0x5bd1e995 + ((((k >>> 16) * 0x5bd1e995) & 0xffff) << 16);\r\n\r\n h = ((h & 0xffff) * 0x5bd1e995 + ((((h >>> 16) * 0x5bd1e995) & 0xffff) << 16)) ^ k;\r\n\r\n l -= 4;\r\n ++i;\r\n } // forgive existing code\r\n\r\n /* eslint-disable no-fallthrough */ switch (l) {\r\n case 3:\r\n h ^= (str.charCodeAt(i + 2) & 0xff) << 16;\r\n case 2:\r\n h ^= (str.charCodeAt(i + 1) & 0xff) << 8;\r\n case 1:\r\n h ^= str.charCodeAt(i) & 0xff;\r\n h = (h & 0xffff) * 0x5bd1e995 + ((((h >>> 16) * 0x5bd1e995) & 0xffff) << 16);\r\n }\r\n /* eslint-enable no-fallthrough */\r\n\r\n h ^= h >>> 13;\r\n h = (h & 0xffff) * 0x5bd1e995 + ((((h >>> 16) * 0x5bd1e995) & 0xffff) << 16);\r\n h ^= h >>> 15;\r\n\r\n return (h >>> 0).toString(36);\r\n}\r\n\r\nfunction generateClassName(objPrevCache, blnRandomPrefix, objStyles, className, sx, props) {\r\n try {\r\n let objClassesNameLocal = {};\r\n\r\n if (objStyles && !className && !sx) {\r\n let lstClasses = Object.entries(objStyles || {});\r\n for (let i = 0; i < lstClasses.length; i++) {\r\n let [classNameMulti, objStyleMulti] = lstClasses[i];\r\n if (!classNameMulti) {\r\n continue;\r\n }\r\n\r\n if (!objPrevCache?.[classNameMulti]) {\r\n let hashPrefix = \"\";\r\n let objStyleAsString = \"\";\r\n if (blnRandomPrefix) {\r\n if (typeof objStyleMulti === \"function\") {\r\n objStyleAsString = JSON.stringify(objStyleMulti(props));\r\n } else {\r\n objStyleAsString = JSON.stringify(objStyleMulti);\r\n }\r\n if (!objStyleAsString) {\r\n objStyleAsString = String(i);\r\n }\r\n hashPrefix = murmurhash2_32_gc(objStyleAsString);\r\n }\r\n\r\n objClassesNameLocal[classNameMulti] = blnRandomPrefix ? `${classNameMulti}_${hashPrefix}` : classNameMulti;\r\n } else {\r\n objClassesNameLocal[classNameMulti] = objPrevCache[classNameMulti];\r\n }\r\n }\r\n } else if (!objStyles && className && sx) {\r\n if (!objPrevCache?.[className]) {\r\n let hashPrefix = \"\";\r\n let objStyleAsString = \"\";\r\n if (blnRandomPrefix) {\r\n if (typeof sx === \"function\") {\r\n objStyleAsString = JSON.stringify(sx(props));\r\n } else {\r\n objStyleAsString = JSON.stringify(sx);\r\n }\r\n\r\n if (!objStyleAsString) {\r\n objStyleAsString = \"\";\r\n }\r\n\r\n hashPrefix = murmurhash2_32_gc(objStyleAsString);\r\n }\r\n\r\n objClassesNameLocal[className] = blnRandomPrefix ? `${className}_${hashPrefix}` : className;\r\n } else {\r\n objClassesNameLocal[className] = objPrevCache[className];\r\n }\r\n }\r\n\r\n return objClassesNameLocal;\r\n } catch (error) {\r\n if (pkgConfigStyle?.blnIsTestingMode) {\r\n console.error(error);\r\n }\r\n if (objStyles && !className) {\r\n return Object.keys(objStyles || {});\r\n } else {\r\n return className;\r\n }\r\n }\r\n}\r\n\r\nfunction generateClassNameOnFly(intIndexInList, blnRandomPrefix, className, objInlineStyle) {\r\n try {\r\n let hashPrefix = \"\";\r\n let objStyleAsString = \"\";\r\n if (blnRandomPrefix) {\r\n objStyleAsString = JSON.stringify(objInlineStyle);\r\n if (!objStyleAsString) {\r\n objStyleAsString = String(intIndexInList);\r\n }\r\n\r\n hashPrefix = murmurhash2_32_gc(objStyleAsString);\r\n }\r\n\r\n return blnRandomPrefix ? `${className}_${hashPrefix}` : className;\r\n } catch (error) {\r\n if (pkgConfigStyle?.blnIsTestingMode) {\r\n console.error(error);\r\n }\r\n return null;\r\n }\r\n}\r\n\r\nexport function setClassHash(_styleRef, _props, { blnRandomPrefix, lstStyleClasses, className, objStyles, sx }) {\r\n try {\r\n if (!_styleRef?.objClassesNames) {\r\n let obj = generateClassName(_styleRef?.objClassesNames, blnRandomPrefix, objStyles, className, sx, _props);\r\n _styleRef.objClassesNames = obj;\r\n _styleRef.prevProps = JSON.stringify(_props);\r\n\r\n return obj;\r\n } else if (_styleRef?.blnInitRun && _styleRef?.objClassesNames && blnRandomPrefix) {\r\n if (JSON.stringify(_props) === _styleRef?.prevProps) {\r\n return _styleRef.objClassesNames;\r\n }\r\n\r\n _styleRef.prevProps = JSON.stringify(_props);\r\n\r\n let obj = _styleRef.objClassesNames;\r\n for (let i = 0; i < lstStyleClasses.length; i++) {\r\n if (!lstStyleClasses?.[i]?.[0]) {\r\n continue;\r\n }\r\n\r\n let strClassName_client = className ? className : lstStyleClasses?.[i]?.[0];\r\n let strClassName_rule = _styleRef.objClassesNames[strClassName_client];\r\n let inlineStyle = lstStyleClasses?.[i]?.[1];\r\n if (typeof inlineStyle !== \"function\") {\r\n continue;\r\n }\r\n\r\n inlineStyle = inlineStyle(_props);\r\n\r\n if (!inlineStyle) {\r\n continue;\r\n }\r\n\r\n let strClassNameCheck = generateClassNameOnFly(i, blnRandomPrefix, strClassName_client, inlineStyle);\r\n\r\n if (strClassNameCheck !== strClassName_rule) {\r\n _styleRef.objClassesNames[strClassName_client] = strClassNameCheck;\r\n obj[strClassName_client] = strClassNameCheck;\r\n _styleRef.objDelMicro = { ..._styleRef?.objDelMicro };\r\n _styleRef.objDelMicro[strClassName_client] = { strClassName_rule: strClassName_rule };\r\n if (_styleRef?.intVersion >= Number.MAX_SAFE_INTEGER) {\r\n _styleRef.intVersion = 1;\r\n }\r\n ++_styleRef.intVersion;\r\n }\r\n }\r\n return obj;\r\n }\r\n return _styleRef?.objClassesNames || {};\r\n } catch (error) {\r\n if (pkgConfigStyle?.blnIsTestingMode) {\r\n console.error(error);\r\n }\r\n return {};\r\n }\r\n}\r\n","// export const getBaseSize=()=>{\r\n// let size=0.25\r\n// if(typeof document !== 'undefined' && typeof localStorage !== \"undefined\"){\r\n// const local = localStorage?.getItem(\"app-themes-base-size\")\r\n// if(!isNaN(Number(local))){\r\n// size = Number(local)\r\n// }\r\n// }\r\n// return size\r\n// }\r\n\r\nexport const defaultBaseSize = 0.25;\r\n\r\nexport const baseSizeXS = 0.15;\r\nexport const baseSizeSM = 0.25;\r\nexport const baseSizeMD = 0.35;\r\nexport const baseSizeLG = 0.4;\r\nexport const baseSizeXL = 0.5;\r\n\r\nexport const globalValues = {\r\n inherit: \"inherit\",\r\n initial: \"initial\",\r\n revert: \"revert\",\r\n revertLayer: \"revert-layer\",\r\n unset: \"unset\",\r\n none: \"none\",\r\n};\r\n\r\nexport const cssKeys = {\r\n //#region color\r\n blue: \"blue\",\r\n indigo: \"indigo\",\r\n purple: \"purple\",\r\n pink: \"pink\",\r\n red: \"red\",\r\n orange: \"orange\",\r\n yellow: \"yellow\",\r\n green: \"green\",\r\n teal: \"teal\",\r\n cyan: \"cyan\",\r\n primary: \"primary\",\r\n secondary: \"secondary\",\r\n success: \"success\",\r\n info: \"info\",\r\n warning: \"warning\",\r\n error: \"error\",\r\n white: \"white\",\r\n black: \"black\",\r\n disabled: \"disabled\",\r\n\r\n gray: \"gray\",\r\n light: \"light\",\r\n dark: \"dark\",\r\n\r\n bodyColor: \"bodyColor\",\r\n bodyColorLight: \"bodyColorLight\",\r\n bodyColorDark: \"bodyColorDark\",\r\n\r\n bodyColorBg: \"bodyColorBg\",\r\n bodyColorBgLight: \"bodyColorBgLight\",\r\n bodyColorBgDark: \"bodyColorBgDark\",\r\n\r\n borderColor: \"borderColor\",\r\n borderColor2: \"borderColor2\",\r\n\r\n currentColor: \"currentColor\",\r\n\r\n inputColor: \"inputColor\",\r\n hover: \"hover\",\r\n\r\n transparent: \"transparent\",\r\n //#endregion\r\n\r\n //#region size\r\n width: \"w\",\r\n height: \"h\",\r\n min: \"min\",\r\n max: \"max\",\r\n\r\n px: \"px\",\r\n auto: \"auto\",\r\n full: \"full\",\r\n half: \"half\",\r\n screen: \"screen\",\r\n\r\n \"3xs\": \"3xs\",\r\n \"2xs\": \"2xs\",\r\n xs: \"xs\",\r\n sm: \"sm\",\r\n md: \"md\",\r\n lg: \"lg\",\r\n xl: \"xl\",\r\n\r\n item_2xs: \"item_2xs\",\r\n item_xs: \"item_xs\",\r\n item_sm: \"item_sm\",\r\n item_md: \"item_md\",\r\n item_lg: \"item_lg\",\r\n item_xl: \"item_xl\",\r\n item_2xl: \"item_2xl\",\r\n\r\n border_2xs: \"border_2xs\",\r\n border_xs: \"border_xs\",\r\n border_sm: \"border_sm\",\r\n border_md: \"border_md\",\r\n border_lg: \"border_lg\",\r\n border_xl: \"border_xl\",\r\n\r\n \"1/2\": \"1/2\",\r\n \"1/3\": \"1/3\",\r\n \"2/3\": \"2/3\",\r\n \"1/4\": \"1/4\",\r\n \"2/4\": \"2/4\",\r\n \"3/4\": \"3/4\",\r\n \"1/5\": \"1/5\",\r\n \"2/5\": \"2/5\",\r\n \"3/5\": \"3/5\",\r\n \"4/5\": \"4/5\",\r\n\r\n \"1/6\": \"1/6\",\r\n \"2/6\": \"2/6\",\r\n \"3/6\": \"3/6\",\r\n \"4/6\": \"4/6\",\r\n \"5/6\": \"5/6\",\r\n\r\n \"1/12\": \"1/12\",\r\n \"2/12\": \"2/12\",\r\n \"3/12\": \"3/12\",\r\n \"4/12\": \"4/12\",\r\n \"5/12\": \"5/12\",\r\n \"6/12\": \"6/12\",\r\n \"7/12\": \"7/12\",\r\n \"8/12\": \"8/12\",\r\n \"9/12\": \"9/12\",\r\n \"10/12\": \"10/12\",\r\n \"11/12\": \"11/12\",\r\n //#endregion\r\n\r\n //#region spacing\r\n mrg: \"m\",\r\n mrgTop: \"mt\",\r\n mrgBottom: \"mb\",\r\n mrgLeft: \"ml\",\r\n mrgRight: \"mr\",\r\n mrgY: \"my\",\r\n mrgX: \"mx\",\r\n\r\n pdn: \"p\",\r\n pdnTop: \"pt\",\r\n pdnBottom: \"pb\",\r\n pdnLeft: \"pl\",\r\n pdnRight: \"pr\",\r\n pdnY: \"py\",\r\n pdnX: \"px\",\r\n //#endregion\r\n\r\n //#region side\r\n x: \"x\",\r\n y: \"y\",\r\n t: \"t\",\r\n b: \"b\",\r\n r: \"r\",\r\n l: \"l\",\r\n start: \"start\",\r\n end: \"end\",\r\n //#endregion\r\n\r\n //#region bg\r\n size: \"size\",\r\n position: \"position\",\r\n attachment: \"attachment\",\r\n repeat: \"repeat\",\r\n clip: \"clip\",\r\n opacity: \"opacity\", //bg-opacity-value (%)\r\n none: \"none\", //bg-none\r\n //#endregion\r\n\r\n //#region border\r\n border: \"border\",\r\n divide: \"divide\",\r\n rounded: \"rounded\",\r\n borderSides: \"borderSides\",\r\n //#endregion\r\n\r\n //#region position\r\n relative: \"relative\",\r\n absolute: \"absolute\",\r\n fixed: \"fixed\",\r\n sticky: \"sticky\",\r\n //#endregion\r\n\r\n //#region text\r\n text: \"text\",\r\n font: \"font\",\r\n break: \"break\",\r\n truncate: \"truncate\",\r\n transform: \"transform\",\r\n h1: \"h1\",\r\n h2: \"h2\",\r\n h3: \"h3\",\r\n h4: \"h4\",\r\n h5: \"h5\",\r\n h6: \"h6\",\r\n subtitle1: \"subtitle1\",\r\n subtitle2: \"subtitle2\",\r\n subtitle3: \"subtitle3\",\r\n body1: \"body1\",\r\n body2: \"body2\",\r\n body3: \"body3\",\r\n caption: \"caption\",\r\n overline: \"overline\",\r\n\r\n fontWeight: \"fontWeight\",\r\n //#endregion\r\n\r\n //#region display\r\n block: \"block\",\r\n flex: \"flex\",\r\n //#endregion\r\n\r\n //#region\r\n contentBox: \"contentBox\",\r\n borderBox: \"borderBox\",\r\n //#endregion\r\n\r\n //#region flex\r\n center: \"center\",\r\n baseline: \"baseline\",\r\n //#endregion\r\n\r\n //#region fontWeight\r\n fontWeight_2xs: \"fontWeight_2xs\",\r\n fontWeight_xs: \"fontWeight_xs\",\r\n fontWeight_sm: \"fontWeight_sm\",\r\n fontWeight_md: \"fontWeight_md\",\r\n fontWeight_lg: \"fontWeight_lg\",\r\n fontWeight_xl: \"fontWeight_xl\",\r\n //#endregion\r\n\r\n //#region\r\n breakSpaces: \"breakSpaces\",\r\n //#endregion\r\n\r\n //#region shadow\r\n shadow: \"shadow\",\r\n xl2: \"2xl\",\r\n inner: \"inner\",\r\n outline: \"outline\",\r\n //#endregion\r\n\r\n baseSize:\"baseSize\",\r\n};\r\n\r\nexport function objCss(baseSize = defaultBaseSize) {\r\n return {\r\n background: {\r\n [cssKeys?.size]: {//bg-value\r\n cover: \"cover\",\r\n contain: \"contain\",\r\n auto: \"auto\",\r\n },\r\n [cssKeys?.position]: {// bg-v-value-h-value\r\n cover: \"top\",\r\n contain: \"bottom\",\r\n center: \"center\",\r\n left: \"left\",\r\n right: \"right\",\r\n },\r\n [cssKeys?.attachment]: {//bg-value\r\n fixed: \"fixed\",\r\n local: \"local\",\r\n scroll: \"scroll\",\r\n },\r\n [cssKeys?.repeat]: {//bg-repeat || bg-repeat-value || bg-no-repeat\r\n repeat: \"repeat\",\r\n no: \"no-repeat\",\r\n x: \"repeat-x\",\r\n y: \"repeat-y\",\r\n round: \"round\",\r\n space: \"space\",\r\n },\r\n [cssKeys?.clip]: {//bg-clip-value\r\n border: \"border-box\",\r\n content: \"content-box\",\r\n padding: \"padding-box\",\r\n text: \"text\",\r\n },\r\n },\r\n border: {\r\n [cssKeys?.border]: {\r\n solid: \"solid\",\r\n dashed: \"dashed\",\r\n dotted: \"dotted\",\r\n none: \"none\",\r\n },\r\n [cssKeys?.divide]: {},\r\n [cssKeys?.rounded]: {\r\n xs: \"0.25rem\",\r\n sm: \"0.5rem\",\r\n md: \"0.75rem\",\r\n lg: \"1rem\",\r\n xl: \"1.5rem\",\r\n pill: \"100%\",\r\n px: \"1px\",\r\n },\r\n [cssKeys?.borderSides]: {\r\n X: \"x\",\r\n y: \"y\",\r\n t: \"t\",\r\n b: \"b\",\r\n r: \"r\",\r\n l: \"l\",\r\n xs: \"xs\",\r\n ys: \"ys\",\r\n xe: \"xe\",\r\n ye: \"ye\",\r\n tr: \"tr\",\r\n tl: \"tl\",\r\n br: \"br\",\r\n bl: \"bl\",\r\n },\r\n [cssKeys?.size]: {\r\n none: \"0px\",\r\n xs: \"1px\",\r\n sm: \"2px\",\r\n md: \"3px\",\r\n lg: \"4px\",\r\n xl: \"5px\",\r\n },\r\n },\r\n color: {\r\n [cssKeys?.blue]: \"#1769aa\",\r\n [cssKeys?.indigo]: \"#6610f2\",\r\n [cssKeys?.purple]: \"#6f42c1\",\r\n [cssKeys?.pink]: \"#e91e63\",\r\n [cssKeys?.red]: \"#dc3545\",\r\n [cssKeys?.orange]: \"#fd7e14\",\r\n [cssKeys?.yellow]: \"#ffcc00\",\r\n [cssKeys?.green]: \"#198754\",\r\n [cssKeys?.teal]: \"#20c997\",\r\n [cssKeys?.cyan]: \"#0dcaf0\",\r\n [cssKeys?.primary]: \"#1769aa\",\r\n [cssKeys?.secondary]: \"#e91e63\",\r\n [cssKeys?.success]: \"#198754\",\r\n [cssKeys?.info]: \"#0dcaf0\",\r\n [cssKeys?.warning]: \"#ffcc00\",\r\n [cssKeys?.error]: \"#dc3545\",\r\n [cssKeys?.white]: \"#ffffff\",\r\n [cssKeys?.black]: \"#000000\",\r\n [cssKeys?.disabled]: \"#bcbcbc\",\r\n [cssKeys?.hover]: \"#a2c3dd\",\r\n\r\n [cssKeys?.gray]: \"#374151\",\r\n [cssKeys?.light]: \"#e5e7eb\",\r\n [cssKeys?.dark]: \"#111827\",\r\n\r\n [cssKeys?.bodyColor]: \"#5a6472\",\r\n [cssKeys?.bodyColorLight]: \"#e5e7eb\",\r\n [cssKeys?.bodyColorDark]: \"#030712\",\r\n\r\n [cssKeys?.transparent]: \"transparent\",\r\n [cssKeys?.bodyColorBg]: \"#f6f6f6\",\r\n [cssKeys?.bodyColorBgLight]: \"#f1f1f1\",\r\n [cssKeys?.bodyColorBgDark]: \"#1f2937\",\r\n\r\n [cssKeys?.borderColor]: \"#9BA4B5\",\r\n [cssKeys?.borderColor2]: \"#212121\",\r\n\r\n [cssKeys?.currentColor]: \"currentColor\",\r\n [cssKeys?.inputColor]: \"#55585c\",\r\n\r\n [`${cssKeys?.primary}_1`]: \"#b9d2e6\",\r\n [`${cssKeys?.primary}_2`]: \"#5d96c4\",\r\n [`${cssKeys?.primary}_3`]: \"#4587bb\",\r\n [`${cssKeys?.primary}_4`]: \"#2e78b3\",\r\n [`${cssKeys?.primary}_5`]: \"#1769aa\",\r\n [`${cssKeys?.primary}_6`]: \"#155f99\",\r\n [`${cssKeys?.primary}_7`]: \"#125488\",\r\n [`${cssKeys?.primary}_8`]: \"#104a77\",\r\n [`${cssKeys?.primary}_9`]: \"#0e3f66\",\r\n },\r\n size: {\r\n [cssKeys?.px]: \"1px\",\r\n [cssKeys?.auto]: \"auto\",\r\n [cssKeys?.full]: \"100%\",\r\n [cssKeys?.half]: \"50%\",\r\n [cssKeys?.screen]: \"100v\",\r\n\r\n [cssKeys?.xs]: \"25%\",\r\n [cssKeys?.sm]: \"41.666667%\",\r\n [cssKeys?.md]: \"58.333333%\",\r\n [cssKeys?.lg]: \"75%\",\r\n [cssKeys?.xl]: \"91.666667%\",\r\n\r\n [cssKeys?.item_2xs]: `${baseSize * 4}rem`,\r\n [cssKeys?.item_xs]: `${baseSize * 6}rem`,\r\n [cssKeys?.item_sm]: `${baseSize * 8}rem`,\r\n [cssKeys?.item_md]: `${baseSize * 10}rem`,\r\n [cssKeys?.item_lg]: `${baseSize * 12}rem`,\r\n [cssKeys?.item_xl]: `${baseSize * 15}rem`,\r\n [cssKeys?.item_2xl]: `${baseSize * 18}rem`,\r\n\r\n [cssKeys?.border_2xs]: `${baseSize / 3}rem`,\r\n [cssKeys?.border_xs]: `${baseSize / 2.5}rem`,\r\n [cssKeys?.border_sm]: `${baseSize / 1.5}rem`,\r\n [cssKeys?.border_md]: `${baseSize * 1}rem`,\r\n [cssKeys?.border_lg]: `${baseSize * 2}rem`,\r\n [cssKeys?.border_xl]: `${baseSize * 3}rem`,\r\n\r\n [cssKeys?.[\"1/2\"]]: \"50%\",\r\n [cssKeys?.[\"1/3\"]]: \"33.333333%\",\r\n [cssKeys?.[\"2/3\"]]: \"66.666667%\",\r\n [cssKeys?.[\"1/4\"]]: \"25%\",\r\n [cssKeys?.[\"2/4\"]]: \"50%\",\r\n [cssKeys?.[\"3/4\"]]: \"75%\",\r\n [cssKeys?.[\"1/5\"]]: \"20%\",\r\n [cssKeys?.[\"2/5\"]]: \"40%\",\r\n [cssKeys?.[\"3/5\"]]: \"60%\",\r\n [cssKeys?.[\"4/5\"]]: \"80%\",\r\n [cssKeys?.[\"1/6\"]]: \"16.666667%\",\r\n [cssKeys?.[\"2/6\"]]: \"33.333333%\",\r\n [cssKeys?.[\"3/6\"]]: \"50%\",\r\n [cssKeys?.[\"4/6\"]]: \"66.666667%\",\r\n [cssKeys?.[\"5/6\"]]: \"83.333333%\",\r\n\r\n [cssKeys?.[\"1/12\"]]: \"8.333333%\",\r\n [cssKeys?.[\"2/12\"]]: \"16.666667%\",\r\n [cssKeys?.[\"3/12\"]]: \"25%\",\r\n [cssKeys?.[\"4/12\"]]: \"33.333333%\",\r\n [cssKeys?.[\"5/12\"]]: \"41.666667%\",\r\n [cssKeys?.[\"6/12\"]]: \"50%\",\r\n [cssKeys?.[\"7/12\"]]: \"58.333333%\",\r\n [cssKeys?.[\"8/12\"]]: \"66.666667%\",\r\n [cssKeys?.[\"9/12\"]]: \"75%\",\r\n [cssKeys?.[\"10/12\"]]: \"83.333333%\",\r\n [cssKeys?.[\"11/12\"]]: \"91.666667%\",\r\n\r\n baseSize: `${baseSize}rem`,\r\n },\r\n spacing: {\r\n [cssKeys?.px]: \"1px\",\r\n [cssKeys?.auto]: \"auto\",\r\n\r\n [cssKeys?.[\"3xs\"]]: `${baseSize / 3}rem`,\r\n [cssKeys?.[\"2xs\"]]: `${baseSize / 2}rem`,\r\n [cssKeys?.xs]: `${baseSize * 1}rem`,\r\n [cssKeys?.sm]: `${baseSize * 2}rem`,\r\n [cssKeys?.md]: `${baseSize * 3}rem`,\r\n [cssKeys?.lg]: `${baseSize * 4}rem`,\r\n [cssKeys?.xl]: `${baseSize * 5}rem`,\r\n },\r\n text: {\r\n [cssKeys?.break]: {\r\n normal: \"normal\",\r\n words: \"break-word\",\r\n all: \"break-all\",\r\n },\r\n [cssKeys?.transform]: {\r\n uppercase: \"uppercase\",\r\n lowercase: \"lowercase\",\r\n capitalize: \"capitalize\",\r\n normalcase: \"none\",\r\n },\r\n [cssKeys?.size]: {\r\n h1: `${baseSize * 13}rem`,\r\n h2: `${baseSize * 10}rem`,\r\n h3: `${baseSize * 7.5}rem`,\r\n h4: `${baseSize * 6.5}rem`,\r\n h5: `${baseSize * 6}rem`,\r\n h6: `${baseSize * 5.25}rem`,\r\n subtitle1: `${baseSize * 5}rem`,\r\n subtitle2: `${baseSize * 4}rem`,\r\n subtitle3: `${baseSize * 3.5}rem`,\r\n body1: `${baseSize * 4.5}rem`,\r\n body2: `${baseSize * 3.8}rem`,\r\n body3: `${baseSize * 3.3}rem`,\r\n caption: `${baseSize * 2.8}rem`,\r\n overline: `${baseSize * 2}rem`,\r\n },\r\n [cssKeys?.fontWeight]: {\r\n fontWeight_2xs: 400,\r\n fontWeight_xs: 500,\r\n fontWeight_sm: 600,\r\n fontWeight_md: 700,\r\n fontWeight_lg: 800,\r\n fontWeight_xl: 900,\r\n },\r\n },\r\n position: {\r\n [cssKeys?.relative]: \"relative\",\r\n [cssKeys?.absolute]: \"absolute\",\r\n [cssKeys?.fixed]: \"fixed\",\r\n [cssKeys?.sticky]: \"sticky\",\r\n },\r\n display: {\r\n [cssKeys?.block]: \"block\",\r\n [cssKeys?.flex]: \"flex\",\r\n },\r\n boxSizing: {\r\n [cssKeys?.contentBox]: \"content-box\",\r\n [cssKeys?.borderBox]: \"border-box\",\r\n ...globalValues,\r\n },\r\n flex: {\r\n [cssKeys?.center]: \"center\",\r\n [cssKeys?.baseline]: \"baseline\",\r\n },\r\n whiteSpace: {\r\n [cssKeys?.breakSpaces]: \"break-spaces\",\r\n },\r\n side: {\r\n [cssKeys?.start]: \"start\",\r\n },\r\n boxShadow: {\r\n [cssKeys?.shadow]: \"0 1px 3px 0 rgba(0, 0, 0, 0.1), 0 1px 2px 0 rgba(0, 0, 0, 0.06)\",\r\n [cssKeys?.inner]: \"inset 0 2px 4px 0 rgba(0, 0, 0, 0.06)\",\r\n [cssKeys?.outline]: \"1px 1px 1px rgba(0, 0, 0, 0.2)\",\r\n [cssKeys?.none]: \"none\",\r\n\r\n [cssKeys?.xl2]: \"0 19px 38px rgba(0,0,0,0.30), 0 15px 12px rgba(0,0,0,0.22)\",// \"0 25px 50px -12px rgba(0, 0, 0, 0.25)\",\r\n [cssKeys?.xl]: \"0 14px 28px rgba(0,0,0,0.25), 0 10px 10px rgba(0,0,0,0.22)\",// \"0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04)\",\r\n [cssKeys?.lg]: \"0 10px 20px rgba(0,0,0,0.19), 0 6px 6px rgba(0,0,0,0.23)\",// \"0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05)\",\r\n [cssKeys?.md]: \"0 3px 6px rgba(0,0,0,0.16), 0 3px 6px rgba(0,0,0,0.23)\",//\"0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.05),\",\r\n [cssKeys?.sm]: \"0 1px 3px rgba(0,0,0,0.12), 0 1px 2px rgba(0,0,0,0.24)\",// \"0 2px 3px -1px rgba(0, 0, 0, 0.05), 0 2px 3px -1px rgba(0, 0, 0, 0.05), 0 2px 3px -1px rgba(0, 0, 0, 0.05), 0 2px 3px -1px rgba(0, 0, 0, 0.05)\",\r\n\r\n [cssKeys?.xs]: \"0 0 0 .5px rgba(0, 0, 0, 0.05), 0 0px 0px .5px rgba(0, 0, 0, 0.05)\",\r\n },\r\n };\r\n}\r\n\r\nexport const mainTheme = {\r\n themes: {},\r\n currentTheme: null,\r\n currentBaseSize: 0.25,\r\n baseSize: 0.25,\r\n cssObject: objCss(0.25),\r\n};\r\n\r\n// --`${styleVariables?.prefixDefaultClassName}`-color-gray\r\n// --`${styleVariables?.prefixDefaultClassName}`-color-dark\r\n// --`${styleVariables?.prefixDefaultClassName}`-color-primary\r\n// --`${styleVariables?.prefixDefaultClassName}`-color-secondary\r\n// --`${styleVariables?.prefixDefaultClassName}`-color-success\r\n// --`${styleVariables?.prefixDefaultClassName}`-color-info\r\n// --`${styleVariables?.prefixDefaultClassName}`-color-warning\r\n// --`${styleVariables?.prefixDefaultClassName}`-color-error\r\n// --`${styleVariables?.prefixDefaultClassName}`-color-light\r\n\r\n// --`${styleVariables?.prefixDefaultClassName}`-color-body\r\n// --`${styleVariables?.prefixDefaultClassName}`-color-light-body\r\n// `--${styleVariables?.prefixDefaultClassName}-color-dark-body`\r\n\r\n// --`${styleVariables?.prefixDefaultClassName}`-color-bg-body\r\n// --`${styleVariables?.prefixDefaultClassName}`-color-bg-light-body\r\n// --`${styleVariables?.prefixDefaultClassName}`-color-bg-dark-body\r\n\r\n// `--${styleVariables?.prefixDefaultClassName}-color-border`:\r\n\r\n// `--${styleVariables?.prefixDefaultClassName}-color-hover`:\r\n\r\n// `--${styleVariables?.prefixDefaultClassName}-h1-font-size\r\n// --`${styleVariables?.prefixDefaultClassName}`-h2-font-size\r\n// --`${styleVariables?.prefixDefaultClassName}`-h3-font-size\r\n// --`${styleVariables?.prefixDefaultClassName}`-h4-font-size\r\n// --`${styleVariables?.prefixDefaultClassName}`-h5-font-size\r\n// --`${styleVariables?.prefixDefaultClassName}`-h6-font-size\r\n// --`${styleVariables?.prefixDefaultClassName}`-subtitle1-font-size\r\n// `--${styleVariables?.prefixDefaultClassName}-subtitle2-font-size`\r\n// --`${styleVariables?.prefixDefaultClassName}`-body1-font-size\r\n// --`${styleVariables?.prefixDefaultClassName}`-body2-font-size\r\n// --`${styleVariables?.prefixDefaultClassName}`-caption-font-size\r\n// --`${styleVariables?.prefixDefaultClassName}`-overline-font-size\r\n\r\n// --`${styleVariables?.prefixDefaultClassName}`-item-size-xs\r\n// --`${styleVariables?.prefixDefaultClassName}`-item-size-sm\r\n// --`${styleVariables?.prefixDefaultClassName}`-item-size-md\r\n// --`${styleVariables?.prefixDefaultClassName}`-item-size-lg\r\n// --`${styleVariables?.prefixDefaultClassName}`-item-size-xl\r\n","import { objCss } from \"../themeProvider/cssVariables\";\r\nconst defaultCssValue = objCss();\r\nexport const checkColorReturnValue = (color) => {\r\n const getColor = String(color).toLowerCase();\r\n return defaultCssValue?.color?.[getColor] || getColor;\r\n};\r\nexport const getShapeReturnClassName = (shape) => {\r\n const theShape = String(shape).toLowerCase();\r\n\r\n switch (theShape) {\r\n case \"circle\":\r\n return \"cbmis-shape-circle\";\r\n case \"oval\":\r\n return \"cbmis-shape-oval\";\r\n case \"square\":\r\n return \"cbmis-shape-square\";\r\n case \"rectangle\":\r\n return \"cbmis-shape-rectangle\";\r\n case \"pentagon\":\r\n return \"cbmis-shape-pentagon\";\r\n case \"hexagon\":\r\n return \"cbmis-shape-hexagon\";\r\n case \"heptagon\":\r\n return \"cbmis-shape-heptagon\";\r\n case \"octagon\":\r\n return \"cbmis-shape-octagon\";\r\n case \"star\":\r\n return \"cbmis-shape-star\";\r\n case \"topchevron\":\r\n return \"cbmis-shape-top-chevron\";\r\n case \"leftchevron\":\r\n return \"cbmis-shape-left-chevron\";\r\n case \"bottomchevron\":\r\n return \"cbmis-shape-bottom-chevron\";\r\n case \"rightchevron\":\r\n return \"cbmis-shape-right-chevron\";\r\n default:\r\n return \"cbmis-shape-circle\";\r\n }\r\n};\r\n/*******************************************margin ***********************************************/\r\nexport const changeItemMarginClassName = (margin) => {\r\n const getArrMargin = String(margin).toLowerCase().split(\"-\");\r\n if (getArrMargin.length === 2) {\r\n switch (getArrMargin[0]) {\r\n case \"m\":\r\n return `cbmis-margin-${getArrMargin[1]}`;\r\n case \"mt\":\r\n return `cbmis-margin-top-${getArrMargin[1]}`;\r\n case \"ml\":\r\n return `cbmis-margin-left-${getArrMargin[1]}`;\r\n case \"mb\":\r\n return `cbmis-margin-bottom-${getArrMargin[1]}`;\r\n case \"mr\":\r\n return `cbmis-margin-right-${getArrMargin[1]}`;\r\n case \"my\":\r\n return `cbmis-margin-y-${getArrMargin[1]}`;\r\n case \"mx\":\r\n return `cbmis-margin-x-${getArrMargin[1]}`;\r\n default:\r\n break;\r\n }\r\n } else if (getArrMargin.length === 3) {\r\n const screenWidth = window.innerWidth;\r\n var marginClassName = \"\";\r\n\r\n switch (getArrMargin[0]) {\r\n case \"m\":\r\n marginClassName = `cbmis-margin-${getArrMargin[2]}`;\r\n break;\r\n case \"mt\":\r\n marginClassName = `cbmis-margin-top-${getArrMargin[2]}`;\r\n break;\r\n case \"ml\":\r\n marginClassName = `cbmis-margin-left-${getArrMargin[2]}`;\r\n break;\r\n case \"mb\":\r\n marginClassName = `cbmis-margin-bottom-${getArrMargin[2]}`;\r\n break;\r\n case \"mr\":\r\n marginClassName = `cbmis-margin-right-${getArrMargin[2]}`;\r\n break;\r\n case \"my\":\r\n marginClassName = `cbmis-margin-y-${getArrMargin[2]}`;\r\n break;\r\n case \"mx\":\r\n marginClassName = `cbmis-margin-x-${getArrMargin[2]}`;\r\n break;\r\n default:\r\n break;\r\n }\r\n if (getArrMargin[1] === \"xs\" && screenWidth < 576) {\r\n return marginClassName;\r\n } else if (getArrMargin[1] === \"sm\" && screenWidth >= 576 && screenWidth < 768) {\r\n return marginClassName;\r\n } else if (getArrMargin[1] === \"md\" && screenWidth >= 768 && screenWidth < 992) {\r\n return marginClassName;\r\n } else if (getArrMargin[1] === \"lg\" && screenWidth >= 992 && screenWidth < 1200) {\r\n return marginClassName;\r\n } else if (getArrMargin[1] === \"xl\" && screenWidth >= 1200) {\r\n return marginClassName;\r\n }\r\n }\r\n};\r\n\r\nexport const checkExistsMargin = (obj) => {\r\n var marginClassesName = \"\";\r\n const margin = Object.keys(obj).filter((item) => item.includes(\"m-\"));\r\n const marginTop = Object.keys(obj).filter((item) => item.includes(\"mt-\"));\r\n const marginLeft = Object.keys(obj).filter((item) => item.includes(\"ml-\"));\r\n const marginBottom = Object.keys(obj).filter((item) => item.includes(\"mb-\"));\r\n const marginRight = Object.keys(obj).filter((item) => item.includes(\"mr-\"));\r\n const marginY = Object.keys(obj).filter((item) => item.includes(\"my-\"));\r\n const marginX = Object.keys(obj).filter((item) => item.includes(\"mx-\"));\r\n\r\n for (let index = 0; index < margin.length; index++) {\r\n marginClassesName += changeItemMarginClassName(margin[index]) + \" \";\r\n }\r\n for (let index = 0; index < marginTop.length; index++) {\r\n marginClassesName += changeItemMarginClassName(marginTop[index]) + \" \";\r\n }\r\n for (let index = 0; index < marginLeft.length; index++) {\r\n marginClassesName += changeItemMarginClassName(marginLeft[index]) + \" \";\r\n }\r\n for (let index = 0; index < marginBottom.length; index++) {\r\n marginClassesName += changeItemMarginClassName(marginBottom[index]) + \" \";\r\n }\r\n for (let index = 0; index < marginRight.length; index++) {\r\n marginClassesName += changeItemMarginClassName(marginRight[index]) + \" \";\r\n }\r\n for (let index = 0; index < marginBottom.length; index++) {\r\n marginClassesName += changeItemMarginClassName(marginBottom[index]) + \" \";\r\n }\r\n for (let index = 0; index < marginRight.length; index++) {\r\n marginClassesName += changeItemMarginClassName(marginRight[index]) + \" \";\r\n }\r\n for (let index = 0; index < marginY.length; index++) {\r\n marginClassesName += changeItemMarginClassName(marginY[index]) + \" \";\r\n }\r\n for (let index = 0; index < marginX.length; index++) {\r\n marginClassesName += changeItemMarginClassName(marginX[index]) + \" \";\r\n }\r\n return marginClassesName;\r\n};\r\n\r\n/*******************************************padding ***********************************************/\r\nexport const changeItemPaddingClassName = (padding) => {\r\n const getArrPadding = String(padding).toLowerCase().split(\"-\");\r\n if (getArrPadding.length === 2) {\r\n switch (getArrPadding[0]) {\r\n case \"p\":\r\n return `cbmis-padding-${getArrPadding[1]}`;\r\n case \"pt\":\r\n return `cbmis-padding-top-${getArrPadding[1]}`;\r\n case \"pl\":\r\n return `cbmis-padding-left-${getArrPadding[1]}`;\r\n case \"pb\":\r\n return `cbmis-padding-bottom-${getArrPadding[1]}`;\r\n case \"pr\":\r\n return `cbmis-padding-right-${getArrPadding[1]}`;\r\n case \"py\":\r\n return `cbmis-padding-y-${getArrPadding[1]}`;\r\n case \"px\":\r\n return `cbmis-padding-x-${getArrPadding[1]}`;\r\n default:\r\n break;\r\n }\r\n } else if (getArrPadding.length === 3) {\r\n const screenWidth = window.innerWidth;\r\n var paddingClassName = \"\";\r\n\r\n switch (getArrPadding[0]) {\r\n case \"p\":\r\n paddingClassName = `cbmis-padding-${getArrPadding[2]}`;\r\n break;\r\n case \"pt\":\r\n paddingClassName = `cbmis-padding-top-${getArrPadding[2]}`;\r\n break;\r\n case \"pl\":\r\n paddingClassName = `cbmis-padding-left-${getArrPadding[2]}`;\r\n break;\r\n case \"pb\":\r\n paddingClassName = `cbmis-padding-bottom-${getArrPadding[2]}`;\r\n break;\r\n case \"pr\":\r\n paddingClassName = `cbmis-padding-right-${getArrPadding[2]}`;\r\n break;\r\n case \"py\":\r\n paddingClassName = `cbmis-padding-y-${getArrPadding[2]}`;\r\n break;\r\n case \"px\":\r\n paddingClassName = `cbmis-padding-x-${getArrPadding[2]}`;\r\n break;\r\n default:\r\n break;\r\n }\r\n if (getArrPadding[1] === \"xs\" && screenWidth < 576) {\r\n return paddingClassName;\r\n } else if (getArrPadding[1] === \"sm\" && screenWidth >= 576 && screenWidth < 768) {\r\n return paddingClassName;\r\n } else if (getArrPadding[1] === \"md\" && screenWidth >= 768 && screenWidth < 992) {\r\n return paddingClassName;\r\n } else if (getArrPadding[1] === \"lg\" && screenWidth >= 992 && screenWidth < 1200) {\r\n return paddingClassName;\r\n } else if (getArrPadding[1] === \"xl\" && screenWidth >= 1200) {\r\n return paddingClassName;\r\n }\r\n }\r\n};\r\n\r\nexport const checkExistsPadding = (obj) => {\r\n var paddingClassesName = \"\";\r\n const padding = Object.keys(obj).filter((item) => item.includes(\"p-\"));\r\n const paddingTop = Object.keys(obj).filter((item) => item.includes(\"pt-\"));\r\n const paddingLeft = Object.keys(obj).filter((item) => item.includes(\"pl-\"));\r\n const paddingBottom = Object.keys(obj).filter((item) => item.includes(\"pb-\"));\r\n const paddingRight = Object.keys(obj).filter((item) => item.includes(\"pr-\"));\r\n const paddingY = Object.keys(obj).filter((item) => item.includes(\"py-\"));\r\n const paddingX = Object.keys(obj).filter((item) => item.includes(\"px-\"));\r\n\r\n for (let index = 0; index < padding.length; index++) {\r\n paddingClassesName += changeItemPaddingClassName(padding[index]) + \" \";\r\n }\r\n for (let index = 0; index < paddingTop.length; index++) {\r\n paddingClassesName += changeItemPaddingClassName(paddingTop[index]) + \" \";\r\n }\r\n for (let index = 0; index < paddingLeft.length; index++) {\r\n paddingClassesName += changeItemPaddingClassName(paddingLeft[index]) + \" \";\r\n }\r\n for (let index = 0; index < paddingBottom.length; index++) {\r\n paddingClassesName += changeItemPaddingClassName(paddingBottom[index]) + \" \";\r\n }\r\n for (let index = 0; index < paddingRight.length; index++) {\r\n paddingClassesName += changeItemPaddingClassName(paddingRight[index]) + \" \";\r\n }\r\n for (let index = 0; index < paddingY.length; index++) {\r\n paddingClassesName += changeItemPaddingClassName(paddingY[index]) + \" \";\r\n }\r\n for (let index = 0; index < paddingX.length; index++) {\r\n paddingClassesName += changeItemPaddingClassName(paddingX[index]) + \" \";\r\n }\r\n return paddingClassesName;\r\n};\r\n\r\nexport const filterPaddingAndMargin = (obj) => {\r\n const rest = Object.entries(obj).filter(([key, value]) => !key.includes(\"p-\") && !key.includes(\"pt-\") && !key.includes(\"pl-\") && !key.includes(\"pb-\") && !key.includes(\"pr-\") && !key.includes(\"px-\") && !key.includes(\"py-\") && !key.includes(\"m-\") && !key.includes(\"mt-\") && !key.includes(\"ml-\") && !key.includes(\"mb-\") && !key.includes(\"mr-\") && !key.includes(\"mx-\") && !key.includes(\"my-\"));\r\n return Object.fromEntries(rest);\r\n};\r\n\r\n///////////////////////////////////////////////////////////////////////////////////////////////////////////\r\nexport function hasClass(el, className) {\r\n try {\r\n if (el.classList) {\r\n return el.classList.contains(className);\r\n }\r\n return !!el.className.match(new RegExp(\"(\\\\s|^)\" + className + \"(\\\\s|$)\"));\r\n } catch {\r\n return false;\r\n }\r\n}\r\n\r\nexport function addClass(el, className) {\r\n try {\r\n if (!hasClass(el, className)) {\r\n if (el.classList) {\r\n el.classList.add(className);\r\n } else {\r\n el.className += \" \" + className;\r\n }\r\n }\r\n } catch {}\r\n}\r\n\r\nexport function removeClass(el, className) {\r\n try {\r\n if (el.classList) {\r\n el.classList.remove(className);\r\n } else if (hasClass(el, className)) {\r\n var reg = new RegExp(\"(\\\\s|^)\" + className + \"(\\\\s|$)\");\r\n el.className = el.className.replace(reg, \" \");\r\n }\r\n } catch {}\r\n}\r\n\r\nexport function replaceClass(el, oldClassName, newClassName) {\r\n try {\r\n if (el.classList) {\r\n el.classList.replace(oldClassName, newClassName);\r\n } else if (hasClass(el, oldClassName)) {\r\n let oldReg = new RegExp(\"(\\\\s|^)\" + oldClassName + \"(\\\\s|$)\");\r\n el.className = el.className.replace(oldReg, newClassName + \" \");\r\n }\r\n } catch {}\r\n}\r\n\r\nexport const generateRandomString = (length) => {\r\n let result = \"\";\r\n const characters = \"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789\";\r\n const charactersLength = characters.length;\r\n for (let i = 0; i < length; i++) {\r\n result += characters.charAt(Math.floor(Math.random() * charactersLength));\r\n }\r\n return result;\r\n};\r\n\r\n/*********************************************************************************************/\r\nexport const CheckDisabledItem = (disabled) => {\r\n if (disabled) {\r\n return \"client_disabled\";\r\n } else {\r\n return \"\";\r\n }\r\n};\r\n\r\nexport const CheckHiddenItem = (hidden) => {\r\n if (hidden) {\r\n return \"client_invisible_hidden\";\r\n } else {\r\n return \"\";\r\n }\r\n};\r\n\r\nexport const CheckDirectionItem = (dir) => {\r\n if (dir) {\r\n return `client_dir_${dir}`;\r\n } else {\r\n return \"\";\r\n }\r\n};\r\n\r\nexport const getRestProps = (rest) => {\r\n const newRest = filterPaddingAndMargin({ ...rest });\r\n return { ...newRest };\r\n};\r\n\r\nexport const getClassName = (...restClassName) => {\r\n let lstClassName = Array.isArray(restClassName) ? restClassName : [];\r\n if (typeof lstClassName[lstClassName.length - 1] === \"undefined\") {\r\n lstClassName.pop();\r\n }\r\n return lstClassName.join(\" \").trim();\r\n};\r\n","export const prefixDefaultClassName = \"uicore\";\r\nexport const defaultBaseSize = 0.25;\r\n\r\n// let xsScrSize = window.matchMedia(\"(max-width: 600px)\");\r\n// let smScrSize = window.matchMedia(\"screen and (min-width: 601px) and (max-width: 900px)\");\r\n// let mdScrSize = window.matchMedia(\"screen and (min-width: 901px) and (max-width: 1200px)\");\r\n// let lgScrSize = window.matchMedia(\"screen and (min-width: 1201px) and (max-width: 1536px)\");\r\n// let xlScrSize = window.matchMedia(\"(min-width: 1537px)\");\r\n\r\nexport const xsScrSize = `@media screen and (max-width: 600px)`;\r\nexport const smScrSize = `@media screen and (max-width: 950px)`;\r\nexport const mdScrSize = `@media screen and (max-width: 1200px)`;\r\nexport const lgScrSize = `@media screen and (max-width: 1537px)`;\r\nexport const xlScrSize = `@media screen and (min-width: 1537px)`;\r\n\r\nexport const xsScr = `600px`;\r\nexport const smScr = `950px`;\r\nexport const mdScr = `1200px`;\r\nexport const lgScr = `1537px`;\r\nexport const xlScr = `1537px`;\r\n","import { lgScrSize, mdScrSize, smScrSize, xlScrSize, xsScrSize } from \"./styleVariables\";\r\n\r\n//#region converter\r\nexport const objCssProperties = {\r\n //#region StandardLonghandProperties\r\n accentColor: \"accent-color\",\r\n alignContent: \"align-content\",\r\n alignItems: \"align-items\",\r\n alignSelf: \"align-self\",\r\n alignTracks: \"align-tracks\",\r\n animationComposition: \"animation-composition\",\r\n animationDelay: \"animation-delay\",\r\n animationDirection: \"animation-direction\",\r\n animationDuration: \"animation-duration\",\r\n animationFillMode: \"animation-fill-mode\",\r\n animationIterationCount: \"animation-iteration-count\",\r\n animationName: \"animation-name\",\r\n animationPlayState: \"animation-play-state\",\r\n animationTimeline: \"animation-timeline\",\r\n animationTimingFunction: \"animation-timing-function\",\r\n appearance: \"appearance\",\r\n aspectRatio: \"aspect-ratio\",\r\n backdropFilter: \"backdrop-filter\",\r\n backfaceVisibility: \"backface-visibility\",\r\n backgroundAttachment: \"background-attachment\",\r\n backgroundBlendMode: \"background-blend-mode\",\r\n backgroundClip: \"background-clip\",\r\n backgroundColor: \"background\",\r\n backgroundImage: \"background-image\",\r\n backgroundOrigin: \"background-origin\",\r\n backgroundPositionX: \"background-position-x\",\r\n backgroundPositionY: \"background-position-y\",\r\n backgroundRepeat: \"background-repeat\",\r\n backgroundSize: \"background-size\",\r\n blockOverflow: \"block-overflow\",\r\n blockSize: \"block-size\",\r\n borderBlockColor: \"border-block-color\",\r\n borderBlockEndColor: \"border-block-end-color\",\r\n borderBlockEndStyle: \"border-block-end-style\",\r\n borderBlockEndWidth: \"border-block-end-width\",\r\n borderBlockStartColor: \"border-block-start-color\",\r\n borderBlockStartStyle: \"border-block-start-style\",\r\n borderBlockStartWidth: \"border-block-start-width\",\r\n borderBlockStyle: \"border-block-style\",\r\n borderBlockWidth: \"border-block-width\",\r\n borderBottomColor: \"border-bottom-color\",\r\n borderBottomLeftRadius: \"border-bottom-left-radius\",\r\n borderBottomRightRadius: \"border-bottom-right-radius\",\r\n borderBottomStyle: \"border-bottom-style\",\r\n borderBottomWidth: \"border-bottom-width\",\r\n borderCollapse: \"border-collapse\",\r\n borderEndEndRadius: \"border-end-end-radius\",\r\n borderEndStartRadius: \"border-end-start-radius\",\r\n borderImageOutset: \"border-image-outset\",\r\n borderImageRepeat: \"border-image-repeat\",\r\n borderImageSlice: \"border-image-slice\",\r\n borderImageSource: \"border-image-source\",\r\n borderImageWidth: \"border-image-width\",\r\n borderInlineColor: \"border-inline-color\",\r\n borderInlineEndColor: \"border-inline-end-color\",\r\n borderInlineEndStyle: \"border-inline-end-style\",\r\n borderInlineEndWidth: \"border-inline-end-width\",\r\n borderInlineStartColor: \"border-inline-start-color\",\r\n borderInlineStartStyle: \"border-inline-start-style\",\r\n borderInlineStartWidth: \"border-inline-start-width\",\r\n borderInlineStyle: \"border-inline-style\",\r\n borderInlineWidth: \"border-inline-width\",\r\n borderLeftColor: \"border-left-color\",\r\n borderLeftStyle: \"border-left-style\",\r\n borderLeftWidth: \"border-left-width\",\r\n borderRightColor: \"border-right-color\",\r\n borderRightStyle: \"border-right-style\",\r\n borderRightWidth: \"border-right-width\",\r\n borderSpacing: \"border-spacing\",\r\n borderStartEndRadius: \"border-start-end-radius\",\r\n borderStartStartRadius: \"border-start-start-radius\",\r\n borderTopColor: \"border-top-color\",\r\n borderTopLeftRadius: \"border-top-left-radius\",\r\n borderTopRightRadius: \"border-top-right-radius\",\r\n borderTopStyle: \"border-top-style\",\r\n borderTopWidth: \"border-top-width\",\r\n bottom: \"bottom\",\r\n boxDecorationBreak: \"box-decoration-break\",\r\n boxShadow: \"box-shadow\",\r\n boxSizing: \"box-sizing\",\r\n breakAfter: \"break-after\",\r\n breakBefore: \"break-before\",\r\n breakInside: \"break-inside\",\r\n captionSide: \"caption-side\",\r\n caretColor: \"caret-color\",\r\n clear: \"clear\",\r\n clipPath: \"clip-path\",\r\n color: \"color\",\r\n colorAdjust: \"color-adjust\",\r\n colorScheme: \"color-scheme\",\r\n columnCount: \"column-count\",\r\n columnFill: \"column-fill\",\r\n columnGap: \"column-gap\",\r\n columnRuleColor: \"column-rule-color\",\r\n columnRuleStyle: \"column-rule-style\",\r\n columnRuleWidth: \"column-rule-width\",\r\n columnSpan: \"column-span\",\r\n columnWidth: \"column-width\",\r\n contain: \"contain\",\r\n content: \"content\",\r\n contentVisibility: \"content-visibility\",\r\n counterIncrement: \"counter-increment\",\r\n counterReset: \"counter-reset\",\r\n counterSet: \"counter-set\",\r\n cursor: \"cursor\",\r\n direction: \"direction\",\r\n display: \"display\",\r\n emptyCells: \"empty-cells\",\r\n filter: \"filter\",\r\n flexBasis: \"flex-basis\",\r\n flexDirection: \"flex-direction\",\r\n flexGrow: \"flex-grow\",\r\n flexShrink: \"flex-shrink\",\r\n flexWrap: \"flex-wrap\",\r\n float: \"float\",\r\n fontFamily: \"font-family\",\r\n fontFeatureSettings: \"font-feature-settings\",\r\n fontKerning: \"font-kerning\",\r\n fontLanguageOverride: \"font-language-override\",\r\n fontOpticalSizing: \"font-optical-sizing\",\r\n fontSize: \"font-size\",\r\n fontSizeAdjust: \"font-size-adjust\",\r\n fontSmooth: \"font-smooth\",\r\n fontStretch: \"font-stretch\",\r\n fontStyle: \"font-style\",\r\n fontSynthesis: \"font-synthesis\",\r\n fontVariant: \"font-variant\",\r\n fontVariantAlternates: \"font-variant-alternates\",\r\n fontVariantCaps: \"font-variant-caps\",\r\n fontVariantEastAsian: \"font-variant-east-asian\",\r\n fontVariantLigatures: \"font-variant-ligatures\",\r\n fontVariantNumeric: \"font-variant-numeric\",\r\n fontVariantPosition: \"font-variant-position\",\r\n fontVariationSettings: \"font-variation-settings\",\r\n fontWeight: \"font-weight\",\r\n forcedColorAdjust: \"forced-color-adjust\",\r\n gridAutoColumns: \"grid-auto-columns\",\r\n gridAutoFlow: \"grid-auto-flow\",\r\n gridAutoRows: \"grid-auto-rows\",\r\n gridColumnEnd: \"grid-column-end\",\r\n gridColumnStart: \"grid-column-start\",\r\n gridRowEnd: \"grid-row-end\",\r\n gridRowStart: \"grid-row-start\",\r\n gridTemplateAreas: \"grid-template-areas\",\r\n gridTemplateColumns: \"grid-template-columns\",\r\n gridTemplateRows: \"grid-template-rows\",\r\n hangingPunctuation: \"hanging-punctuation\",\r\n height: \"height\",\r\n hyphenateCharacter: \"hyphenate-character\",\r\n hyphens: \"hyphens\",\r\n imageOrientation: \"image-orientation\",\r\n imageRendering: \"image-rendering\",\r\n imageResolution: \"image-resolution\",\r\n initialLetter: \"initial-letter\",\r\n inlineSize: \"inline-size\",\r\n inputSecurity: \"input-security\",\r\n inset: \"inset\",\r\n insetBlock: \"inset-block\",\r\n insetBlockEnd: \"inset-block-end\",\r\n insetBlockStart: \"inset-block-start\",\r\n insetInline: \"inset-inline\",\r\n insetInlineEnd: \"inset-inline-end\",\r\n insetInlineStart: \"inset-inline-start\",\r\n isolation: \"isolation\",\r\n justifyContent: \"justify-content\",\r\n justifyItems: \"justify-items\",\r\n justifySelf: \"justify-self\",\r\n justifyTracks: \"justify-tracks\",\r\n left: \"left\",\r\n letterSpacing: \"letter-spacing\",\r\n lineBreak: \"line-break\",\r\n lineHeight: \"line-height\",\r\n lineHeightStep: \"line-height-step\",\r\n listStyleImage: \"list-style-image\",\r\n listStylePosition: \"list-style-position\",\r\n listStyleType: \"list-style-type\",\r\n marginBlock: \"margin-block\",\r\n marginBlockEnd: \"margin-block-end\",\r\n marginBlockStart: \"margin-block-start\",\r\n marginBottom: \"margin-bottom\",\r\n marginInline: \"margin-inline\",\r\n marginInlineEnd: \"margin-inline-end\",\r\n marginInlineStart: \"margin-inline-start\",\r\n marginLeft: \"margin-left\",\r\n marginRight: \"margin-right\",\r\n marginTop: \"margin-top\",\r\n maskBorderMode: \"mask-border-mode\",\r\n maskBorderOutset: \"mask-border-outset\",\r\n maskBorderRepeat: \"mask-border-repeat\",\r\n maskBorderSlice: \"mask-border-slice\",\r\n maskBorderSource: \"mask-border-source\",\r\n maskBorderWidth: \"mask-border-width\",\r\n maskClip: \"mask-clip\",\r\n maskComposite: \"mask-composite\",\r\n maskImage: \"mask-image\",\r\n maskMode: \"mask-mode\",\r\n maskOrigin: \"mask-origin\",\r\n maskPosition: \"mask-position\",\r\n maskRepeat: \"mask-repeat\",\r\n maskSize: \"mask-size\",\r\n maskType: \"mask-type\",\r\n mathDepth: \"math-depth\",\r\n mathShift: \"math-shift\",\r\n mathStyle: \"math-style\",\r\n maxBlockSize: \"max-block-size\",\r\n maxHeight: \"max-height\",\r\n maxInlineSize: \"max-inline-size\",\r\n maxLines: \"max-lines\",\r\n maxWidth: \"max-width\",\r\n minBlockSize: \"min-block-size\",\r\n minHeight: \"min-height\",\r\n minInlineSize: \"min-inline-size\",\r\n minWidth: \"min-width\",\r\n mixBlendMode: \"mix-blend-mode\",\r\n motionDistance: \"motion-distance\",\r\n motionPath: \"motion-path\",\r\n motionRotation: \"motion-rotation\",\r\n objectFit: \"object-fit\",\r\n objectPosition: \"object-position\",\r\n offsetAnchor: \"offset-anchor\",\r\n offsetDistance: \"offset-distance\",\r\n offsetPath: \"offset-path\",\r\n offsetRotate: \"offset-rotate\",\r\n offsetRotation: \"offset-rotation\",\r\n opacity: \"opacity\",\r\n order: \"order\",\r\n orphans: \"orphans\",\r\n outlineColor: \"outline-color\",\r\n outlineOffset: \"outline-offset\",\r\n outlineStyle: \"outline-style\",\r\n outlineWidth: \"outline-width\",\r\n overflowAnchor: \"overflow-anchor\",\r\n overflowBlock: \"overflow-block\",\r\n overflowClipBox: \"overflow-clip-box\",\r\n overflowClipMargin: \"overflow-clip-margin\",\r\n overflowInline: \"overflow-inline\",\r\n overflowWrap: \"overflow-wrap\",\r\n overflowX: \"overflow-x\",\r\n overflowY: \"overflow-y\",\r\n overscrollBehaviorBlock: \"overscroll-behavior-block\",\r\n overscrollBehaviorInline: \"overscroll-behavior-inline\",\r\n overscrollBehaviorX: \"overscroll-behavior-x\",\r\n overscrollBehaviorY: \"overscroll-behavior-y\",\r\n paddingBlock: \"padding-block\",\r\n paddingBlockEnd: \"padding-block-end\",\r\n paddingBlockStart: \"padding-block-start\",\r\n paddingBottom: \"padding-bottom\",\r\n paddingInline: \"padding-inline\",\r\n paddingInlineEnd: \"padding-inline-end\",\r\n paddingInlineStart: \"padding-inline-start\",\r\n paddingLeft: \"padding-left\",\r\n paddingRight: \"padding-right\",\r\n paddingTop: \"padding-top\",\r\n pageBreakAfter: \"page-break-after\",\r\n pageBreakBefore: \"page-break-before\",\r\n pageBreakInside: \"page-break-inside\",\r\n paintOrder: \"paint-order\",\r\n perspective: \"perspective\",\r\n perspectiveOrigin: \"perspective-origin\",\r\n placeContent: \"place-content\",\r\n pointerEvents: \"pointer-events\",\r\n position: \"position\",\r\n printColorAdjust: \"print-color-adjust\",\r\n quotes: \"quotes\",\r\n resize: \"resize\",\r\n right: \"right\",\r\n rotate: \"rotate\",\r\n rowGap: \"row-gap\",\r\n rubyAlign: \"ruby-align\",\r\n rubyMerge: \"ruby-merge\",\r\n rubyPosition: \"ruby-position\",\r\n scale: \"scale\",\r\n scrollBehavior: \"scroll-behavior\",\r\n scrollMargin: \"scroll-margin\",\r\n scrollMarginBlock: \"scroll-margin-block\",\r\n scrollMarginBlockEnd: \"scroll-margin-block-end\",\r\n scrollMarginBlockStart: \"scroll-margin-block-start\",\r\n scrollMarginBottom: \"scroll-margin-bottom\",\r\n scrollMarginInline: \"scroll-margin-inline\",\r\n scrollMarginInlineEnd: \"scroll-margin-inline-end\",\r\n scrollMarginInlineStart: \"scroll-margin-inline-start\",\r\n scrollMarginLeft: \"scroll-margin-left\",\r\n scrollMarginRight: \"scroll-margin-right\",\r\n scrollMarginTop: \"scroll-margin-top\",\r\n scrollPadding: \"scroll-padding\",\r\n scrollPaddingBlock: \"scroll-padding-block\",\r\n scrollPaddingBlockEnd: \"scroll-padding-block-end\",\r\n scrollPaddingBlockStart: \"scroll-padding-block-start\",\r\n scrollPaddingBottom: \"scroll-padding-bottom\",\r\n scrollPaddingInline: \"scroll-padding-inline\",\r\n scrollPaddingInlineEnd: \"scroll-padding-inline-end\",\r\n scrollPaddingInlineStart: \"scroll-padding-inline-start\",\r\n scrollPaddingLeft: \"scroll-padding-left\",\r\n scrollPaddingRight: \"scroll-padding-right\",\r\n scrollPaddingTop: \"scroll-padding-top\",\r\n scrollSnapAlign: \"scroll-snap-align\",\r\n scrollSnapMargin: \"scroll-snap-margin\",\r\n scrollSnapMarginBottom: \"scroll-snap-margin-bottom\",\r\n scrollSnapMarginLeft: \"scroll-snap-margin-left\",\r\n scrollSnapMarginRight: \"scroll-snap-margin-right\",\r\n scrollSnapMarginTop: \"scroll-snap-margin-top\",\r\n scrollSnapStop: \"scroll-snap-stop\",\r\n scrollSnapType: \"scroll-snap-type\",\r\n scrollbarColor: \"scrollbar-color\",\r\n scrollbarGutter: \"scrollbar-gutter\",\r\n scrollbarWidth: \"scrollbar-width\",\r\n shapeImageThreshold: \"shape-image-threshold\",\r\n shapeMargin: \"shape-margin\",\r\n shapeOutside: \"shape-outside\",\r\n tabSize: \"tab-size\",\r\n tableLayout: \"table-layout\",\r\n textAlign: \"text-align\",\r\n textAlignLast: \"text-align-last\",\r\n textCombineUpright: \"text-combine-upright\",\r\n textDecorationColor: \"text-decoration-color\",\r\n textDecorationLine: \"text-decoration-line\",\r\n textDecorationSkip: \"text-decoration-skip\",\r\n textDecorationSkipInk: \"text-decoration-skip-ink\",\r\n textDecorationStyle: \"text-decoration-style\",\r\n textDecorationThickness: \"text-decoration-thickness\",\r\n textEmphasisColor: \"text-emphasis-color\",\r\n textEmphasisPosition: \"text-emphasis-position\",\r\n textEmphasisStyle: \"text-emphasis-style\",\r\n textIndent: \"text-indent\",\r\n textJustify: \"text-justify\",\r\n textOrientation: \"text-orientation\",\r\n textOverflow: \"text-overflow\",\r\n textRendering: \"text-rendering\",\r\n textShadow: \"text-shadow\",\r\n textSizeAdjust: \"text-size-adjust\",\r\n textTransform: \"text-transform\",\r\n textUnderlineOffset: \"text-underline-offset\",\r\n textUnderlinePosition: \"text-underline-position\",\r\n top: \"top\",\r\n touchAction: \"touch-action\",\r\n transform: \"transform\",\r\n transformBox: \"transform-box\",\r\n transformOrigin: \"transform-origin\",\r\n transformStyle: \"transform-style\",\r\n transitionDelay: \"transition-delay\",\r\n transitionDuration: \"transition-duration\",\r\n transitionProperty: \"transition-property\",\r\n transitionTimingFunction: \"transition-timing-function\",\r\n translate: \"translate\",\r\n unicodeBidi: \"unicode-bidi\",\r\n userSelect: \"user-select\",\r\n verticalAlign: \"vertical-align\",\r\n visibility: \"visibility\",\r\n whiteSpace: \"white-space\",\r\n widows: \"widows\",\r\n width: \"width\",\r\n willChange: \"will-change\",\r\n wordBreak: \"word-break\",\r\n wordSpacing: \"word-spacing\",\r\n wordWrap: \"word-wrap\",\r\n writingMode: \"writing-mode\",\r\n zIndex: \"z-index\",\r\n zoom: \"zoom\",\r\n //#endregion\r\n ////////////////////////////////////////////////////////////////////////////////////////////\r\n //#region StandardShorthandProperties\r\n all: \"all\",\r\n animation: \"animation\",\r\n background: \"background\",\r\n backgroundPosition: \"background-position\",\r\n border: \"border\",\r\n borderBlock: \"border-block\",\r\n borderBlockEnd: \"border-block-end\",\r\n borderBlockStart: \"border-block-start\",\r\n borderBottom: \"border-bottom\",\r\n borderColor: \"border-color\",\r\n borderImage: \"border-image\",\r\n borderInline: \"border-inline\",\r\n borderInlineEnd: \"border-inline-end\",\r\n borderInlineStart: \"border-inline-start\",\r\n borderLeft: \"border-left\",\r\n borderRadius: \"border-radius\",\r\n borderRight: \"border-right\",\r\n borderStyle: \"border-style\",\r\n borderTop: \"border-top\",\r\n borderWidth: \"border-width\",\r\n columnRule: \"column-rule\",\r\n columns: \"columns\",\r\n flex: \"flex\",\r\n flexFlow: \"flex-flow\",\r\n font: \"font\",\r\n gap: \"gap\",\r\n grid: \"grid\",\r\n gridArea: \"grid-area\",\r\n gridColumn: \"grid-column\",\r\n gridRow: \"grid-row\",\r\n gridTemplate: \"grid-template\",\r\n lineClamp: \"line-clamp\",\r\n listStyle: \"list-style\",\r\n margin: \"margin\",\r\n mask: \"mask\",\r\n maskBorder: \"mask-border\",\r\n motion: \"motion\",\r\n offset: \"offset\",\r\n outline: \"outline\",\r\n overflow: \"overflow\",\r\n overscrollBehavior: \"overscroll-behavior\",\r\n padding: \"padding\",\r\n placeItems: \"place-items\",\r\n placeSelf: \"place-self\",\r\n textDecoration: \"text-decoration\",\r\n textEmphasis: \"text-emphasis\",\r\n transition: \"transition\",\r\n //#endregion\r\n ////////////////////////////////////////////////////////////////////////////////////////////\r\n //#region VendorLonghandProperties\r\n MozAnimationDelay: \"-moz-animation-delay\",\r\n MozAnimationDirection: \"-moz-animation-direction\",\r\n MozAnimationDuration: \"-moz-animation-duration\",\r\n MozAnimationFillMode: \"-moz-animation-fill-mode\",\r\n MozAnimationIterationCount: \"-moz-animation-iteration-count\",\r\n MozAnimationName: \"-moz-animation-name\",\r\n MozAnimationPlayState: \"-moz-animation-play-state\",\r\n MozAnimationTimingFunction: \"-moz-animation-timing-function\",\r\n MozAppearance: \"-moz-appearance\",\r\n MozBackfaceVisibility: \"-moz-backface-visibility\",\r\n MozBorderBottomColors: \"-moz-border-bottom-colors\",\r\n MozBorderEndColor: \"-moz-border-end-color\",\r\n MozBorderEndStyle: \"-moz-border-end-style\",\r\n MozBorderEndWidth: \"-moz-border-end-width\",\r\n MozBorderLeftColors: \"-moz-border-left-colors\",\r\n MozBorderRightColors: \"-moz-border-right-colors\",\r\n MozBorderStartColor: \"-moz-border-start-color\",\r\n MozBorderStartStyle: \"-moz-border-start-style\",\r\n MozBorderTopColors: \"-moz-border-top-colors\",\r\n MozBoxSizing: \"-moz-box-sizing\",\r\n MozColumnCount: \"-moz-column-count\",\r\n MozColumnFill: \"-moz-column-fill\",\r\n MozColumnRuleColor: \"-moz-column-rule-color\",\r\n MozColumnRuleStyle: \"-moz-column-rule-style\",\r\n MozColumnRuleWidth: \"-moz-column-rule-width\",\r\n MozColumnWidth: \"-moz-column-width\",\r\n MozContextProperties: \"-moz-context-properties\",\r\n MozFontFeatureSettings: \"-moz-font-feature-settings\",\r\n MozFontLanguageOverride: \"-moz-font-language-override\",\r\n MozHyphens: \"-moz-hyphens\",\r\n MozImageRegion: \"-moz-image-region\",\r\n MozMarginEnd: \"-moz-margin-end\",\r\n MozMarginStart: \"-moz-margin-start\",\r\n MozOrient: \"-moz-orient\",\r\n MozOsxFontSmoothing: \"-moz-osx-font-smoothing\",\r\n MozPaddingEnd: \"-moz-padding-end\",\r\n MozPaddingStart: \"-moz-padding-start\",\r\n MozPerspective: \"-moz-perspective\",\r\n MozPerspectiveOrigin: \"-moz-perspective-origin\",\r\n MozStackSizing: \"-moz-stack-sizing\",\r\n MozTabSize: \"-moz-tab-size\",\r\n MozTextBlink: \"-moz-text-blink\",\r\n MozTextSizeAdjust: \"-moz-text-size-adjust\",\r\n MozTransformOrigin: \"-moz-transform-origin\",\r\n MozTransformStyle: \"-moz-transform-style\",\r\n MozTransitionDelay: \"-moz-transition-delay\",\r\n MozTransitionDuration: \"-moz-transition-duration\",\r\n MozTransitionProperty: \"-moz-transition-property\",\r\n MozTransitionTimingFunction: \"-moz-transition-timing-function\",\r\n MozUserFocus: \"-moz-user-focus\",\r\n MozUserModify: \"-moz-user-modify\",\r\n MozUserSelect: \"-moz-user-select\",\r\n MozWindowDragging: \"-moz-window-dragging\",\r\n MozWindowShadow: \"-moz-window-shadow\",\r\n WebkitAlignContent: \"-webkit-align-content\",\r\n WebkitAlignItems: \"-webkit-align-items\",\r\n WebkitAlignSelf: \"-webkit-align-self\",\r\n WebkitAnimationDelay: \"-webkit-animation-delay\",\r\n WebkitAnimationDirection: \"-webkit-animation-direction\",\r\n WebkitAnimationDuration: \"-webkit-animation-duration\",\r\n WebkitAnimationFillMode: \"-webkit-animation-fill-mode\",\r\n WebkitAnimationIterationCount: \"-webkit-animation-iteration-count\",\r\n WebkitAnimationName: \"-webkit-animation-name\",\r\n WebkitAnimationPlayState: \"-webkit-animation-play-state\",\r\n WebkitAnimationTimingFunction: \"-webkit-animation-timing-function\",\r\n WebkitAppearance: \"-webkit-appearance\",\r\n WebkitBackdropFilter: \"-webkit-backdrop-filter\",\r\n WebkitBackfaceVisibility: \"-webkit-backface-visibility\",\r\n WebkitBackgroundClip: \"-webkit-background-clip\",\r\n WebkitBackgroundOrigin: \"-webkit-background-origin\",\r\n WebkitBackgroundSize: \"-webkit-background-size\",\r\n WebkitBorderBeforeColor: \"-webkit-border-before-color\",\r\n WebkitBorderBeforeStyle: \"-webkit-border-before-style\",\r\n WebkitBorderBeforeWidth: \"-webkit-border-before-width\",\r\n WebkitBorderBottomLeftRadius: \"-webkit-border-bottom-left-radius\",\r\n WebkitBorderBottomRightRadius: \"-webkit-border-bottom-right-radius\",\r\n WebkitBorderImageSlice: \"-webkit-border-image-slice\",\r\n WebkitBorderTopLeftRadius: \"-webkit-border-top-left-radius\",\r\n WebkitBorderTopRightRadius: \"-webkit-border-top-right-radius\",\r\n WebkitBoxDecorationBreak: \"-webkit-box-decoration-break\",\r\n WebkitBoxReflect: \"-webkit-box-reflect\",\r\n WebkitBoxShadow: \"-webkit-box-shadow\",\r\n WebkitBoxSizing: \"-webkit-box-sizing\",\r\n WebkitClipPath: \"-webkit-clip-path\",\r\n WebkitColumnCount: \"-webkit-column-count\",\r\n WebkitColumnFill: \"-webkit-column-fill\",\r\n WebkitColumnRuleColor: \"-webkit-column-rule-color\",\r\n WebkitColumnRuleStyle: \"-webkit-column-rule-style\",\r\n WebkitColumnRuleWidth: \"-webkit-column-rule-width\",\r\n WebkitColumnSpan: \"-webkit-column-span\",\r\n WebkitColumnWidth: \"-webkit-column-width\",\r\n WebkitFilter: \"-webkit-filter\",\r\n WebkitFlexBasis: \"-webkit-flex-basis\",\r\n WebkitFlexDirection: \"-webkit-flex-direction\",\r\n WebkitFlexGrow: \"-webkit-flex-grow\",\r\n WebkitFlexShrink: \"-webkit-flex-shrink\",\r\n WebkitFlexWrap: \"-webkit-flex-wrap\",\r\n WebkitFontFeatureSettings: \"-webkit-font-feature-settings\",\r\n WebkitFontKerning: \"-webkit-font-kerning\",\r\n WebkitFontSmoothing: \"-webkit-font-smoothing\",\r\n WebkitFontVariantLigatures: \"-webkit-font-variant-ligatures\",\r\n WebkitHyphenateCharacter: \"-webkit-hyphenate-character\",\r\n WebkitHyphens: \"-webkit-hyphens\",\r\n WebkitInitialLetter: \"-webkit-initial-letter\",\r\n WebkitJustifyContent: \"-webkit-justify-content\",\r\n WebkitLineBreak: \"-webkit-line-break\",\r\n WebkitLineClamp: \"-webkit-line-clamp\",\r\n WebkitMarginEnd: \"-webkit-margin-end\",\r\n WebkitMarginStart: \"-webkit-margin-start\",\r\n WebkitMaskAttachment: \"-webkit-mask-attachment\",\r\n WebkitMaskBoxImageOutset: \"-webkit-mask-box-image-outset\",\r\n WebkitMaskBoxImageRepeat: \"-webkit-mask-box-image-repeat\",\r\n WebkitMaskBoxImageSlice: \"-webkit-mask-box-image-slice\",\r\n WebkitMaskBoxImageSource: \"-webkit-mask-box-image-source\",\r\n WebkitMaskBoxImageWidth: \"-webkit-mask-box-image-width\",\r\n WebkitMaskClip: \"-webkit-mask-clip\",\r\n WebkitMaskComposite: \"-webkit-mask-composite\",\r\n WebkitMaskImage: \"-webkit-mask-image\",\r\n WebkitMaskOrigin: \"-webkit-mask-origin\",\r\n WebkitMaskPosition: \"-webkit-mask-position\",\r\n WebkitMaskPositionX: \"-webkit-mask-position-x\",\r\n WebkitMaskPositionY: \"-webkit-mask-position-y\",\r\n WebkitMaskRepeat: \"-webkit-mask-repeat\",\r\n WebkitMaskRepeatX: \"-webkit-mask-repeat-x\",\r\n WebkitMaskRepeatY: \"-webkit-mask-repeat-y\",\r\n WebkitMaskSize: \"-webkit-mask-size\",\r\n WebkitMaxInlineSize: \"-webkit-max-inline-size\",\r\n WebkitOrder: \"-webkit-order\",\r\n WebkitOverflowScrolling: \"-webkit-overflow-scrolling\",\r\n WebkitPaddingEnd: \"-webkit-padding-end\",\r\n WebkitPaddingStart: \"-webkit-padding-start\",\r\n WebkitPerspective: \"-webkit-perspective\",\r\n WebkitPerspectiveOrigin: \"-webkit-perspective-origin\",\r\n WebkitPrintColorAdjust: \"-webkit-print-color-adjust\",\r\n WebkitRubyPosition: \"-webkit-ruby-position\",\r\n WebkitScrollSnapType: \"-webkit-scroll-snap-type\",\r\n WebkitShapeMargin: \"-webkit-shape-margin\",\r\n WebkitTapHighlightColor: \"-webkit-tap-highlight-color\",\r\n WebkitTextCombine: \"-webkit-text-combine\",\r\n WebkitTextDecorationColor: \"-webkit-text-decoration-color\",\r\n WebkitTextDecorationLine: \"-webkit-text-decoration-line\",\r\n WebkitTextDecorationSkip: \"-webkit-text-decoration-skip\",\r\n WebkitTextDecorationStyle: \"-webkit-text-decoration-style\",\r\n WebkitTextEmphasisColor: \"-webkit-text-emphasis-color\",\r\n WebkitTextEmphasisPosition: \"-webkit-text-emphasis-position\",\r\n WebkitTextEmphasisStyle: \"-webkit-text-emphasis-style\",\r\n WebkitTextFillColor: \"-webkit-text-fill-color\",\r\n WebkitTextOrientation: \"-webkit-text-orientation\",\r\n WebkitTextSizeAdjust: \"-webkit-text-size-adjust\",\r\n WebkitTextStrokeColor: \"-webkit-text-stroke-color\",\r\n WebkitTextStrokeWidth: \"-webkit-text-stroke-width\",\r\n WebkitTextUnderlinePosition: \"-webkit-text-underline-position\",\r\n WebkitTouchCallout: \"-webkit-touch-callout\",\r\n WebkitTransform: \"-webkit-transform\",\r\n WebkitTransformOrigin: \"-webkit-transform-origin\",\r\n WebkitTransformStyle: \"-webkit-transform-style\",\r\n WebkitTransition: \"-webkit-transition\",\r\n WebkitTransitionDelay: \"-webkit-transition-delay\",\r\n WebkitTransitionDuration: \"-webkit-transition-duration\",\r\n WebkitTransitionProperty: \"-webkit-transition-property\",\r\n WebkitTransitionTimingFunction: \"-webkit-transition-timing-function\",\r\n WebkitUserModify: \"-webkit-user-modify\",\r\n WebkitUserSelect: \"-webkit-user-select\",\r\n WebkitWritingMode: \"-webkit-writing-mode\",\r\n WebkitCalendarPickerIndicator: \"-webkit-calendar-picker-indicator\",\r\n //#endregion\r\n ////////////////////////////////////////////////////////////////////////////////////////////\r\n //#region VendorShorthandProperties\r\n MozAnimation: \"-moz-animation\",\r\n MozBorderImage: \"-moz-border-image\",\r\n MozColumnRule: \"-moz-column-rule\",\r\n MozColumns: \"-moz-columns\",\r\n MozTransition: \"-moz-transition\",\r\n WebkitAnimation: \"-webkit-animation\",\r\n WebkitBorderBefore: \"-webkit-border-before\",\r\n WebkitBorderImage: \"-webkit-border-image\",\r\n WebkitBorderRadius: \"-webkit-border-radius\",\r\n WebkitColumnRule: \"-webkit-column-rule\",\r\n WebkitColumns: \"-webkit-columns\",\r\n WebkitFlex: \"-webkit-flex\",\r\n WebkitFlexFlow: \"-webkit-flex-flow\",\r\n WebkitMask: \"-webkit-mask\",\r\n WebkitMaskBoxImage: \"-webkit-mask-box-image\",\r\n WebkitTextEmphasis: \"-webkit-text-emphasis\",\r\n WebkitTextStroke: \"-webkit-text-stroke\",\r\n //#endregion\r\n ////////////////////////////////////////////////////////////////////////////////////////////\r\n //#region ObsoleteProperties\r\n azimuth: \"azimuth\",\r\n boxAlign: \"box-align\",\r\n boxDirection: \"box-direction\",\r\n boxFlex: \"box-flex\",\r\n boxFlexGroup: \"box-flex-group\",\r\n boxLines: \"box-lines\",\r\n boxOrdinalGroup: \"box-ordinal-group\",\r\n boxOrient: \"box-orient\",\r\n boxPack: \"box-pack\",\r\n clip: \"clip\",\r\n gridColumnGap: \"grid-column-gap\",\r\n gridGap: \"grid-gap\",\r\n gridRowGap: \"grid-row-gap\",\r\n imeMode: \"ime-mode\",\r\n offsetBlock: \"offset-block\",\r\n offsetBlockEnd: \"offset-block-end\",\r\n offsetBlockStart: \"offset-block-start\",\r\n offsetInline: \"offset-inline\",\r\n offsetInlineEnd: \"offset-inline-end\",\r\n offsetInlineStart: \"offset-inline-start\",\r\n scrollSnapCoordinate: \"scroll-snap-coordinate\",\r\n scrollSnapDestination: \"scroll-snap-destination\",\r\n scrollSnapPointsX: \"scroll-snap-points-x\",\r\n scrollSnapPointsY: \"scroll-snap-points-y\",\r\n scrollSnapTypeX: \"scroll-snap-type-x\",\r\n scrollSnapTypeY: \"scroll-snap-type-y\",\r\n KhtmlBoxAlign: \"-khtml-box-align\",\r\n KhtmlBoxDirection: \"-khtml-box-direction\",\r\n KhtmlBoxFlex: \"-khtml-box-flex\",\r\n KhtmlBoxFlexGroup: \"-khtml-box-flex-group\",\r\n KhtmlBoxLines: \"-khtml-box-lines\",\r\n KhtmlBoxOrdinalGroup: \"-khtml-box-ordinal-group\",\r\n KhtmlBoxOrient: \"-khtml-box-orient\",\r\n KhtmlBoxPack: \"-khtml-box-pack\",\r\n KhtmlLineBreak: \"-khtml-line-break\",\r\n KhtmlOpacity: \"-khtml-opacity\",\r\n KhtmlUserSelect: \"-khtml-user-select\",\r\n MozBackgroundClip: \"-moz-background-clip\",\r\n MozBackgroundInlinePolicy: \"-moz-background-inline-policy\",\r\n MozBackgroundOrigin: \"-moz-background-origin\",\r\n MozBackgroundSize: \"-moz-background-size\",\r\n MozBinding: \"-moz-binding\",\r\n MozBorderRadius: \"-moz-border-radius\",\r\n MozBorderRadiusBottomleft: \"-moz-border-radius-bottomleft\",\r\n MozBorderRadiusBottomright: \"-moz-border-radius-bottomright\",\r\n MozBorderRadiusTopleft: \"-moz-border-radius-topleft\",\r\n MozBorderRadiusTopright: \"-moz-border-radius-topright\",\r\n MozBoxAlign: \"-moz-box-align\",\r\n MozBoxDirection: \"-moz-box-direction\",\r\n MozBoxFlex: \"-moz-box-flex\",\r\n MozBoxOrdinalGroup: \"-moz-box-ordinal-group\",\r\n MozBoxOrient: \"-moz-box-orient\",\r\n MozBoxPack: \"-moz-box-pack\",\r\n MozBoxShadow: \"-moz-box-shadow\",\r\n MozFloatEdge: \"-moz-float-edge\",\r\n MozForceBrokenImageIcon: \"-moz-force-broken-image-icon\",\r\n MozOpacity: \"-moz-opacity\",\r\n MozOutline: \"-moz-outline\",\r\n MozOutlineColor: \"-moz-outline-color\",\r\n MozOutlineRadius: \"-moz-outline-radius\",\r\n MozOutlineRadiusBottomleft: \"-moz-outline-radius-bottomleft\",\r\n MozOutlineRadiusBottomright: \"-moz-outline-radius-bottomright\",\r\n MozOutlineRadiusTopleft: \"-moz-outline-radius-topleft\",\r\n MozOutlineRadiusTopright: \"-moz-outline-radius-topright\",\r\n MozOutlineStyle: \"-moz-outline-style\",\r\n MozOutlineWidth: \"-moz-outline-width\",\r\n MozTextAlignLast: \"-moz-text-align-last\",\r\n MozTextDecorationColor: \"-moz-text-decoration-color\",\r\n MozTextDecorationLine: \"-moz-text-decoration-line\",\r\n MozTextDecorationStyle: \"-moz-text-decoration-style\",\r\n MozUserInput: \"-moz-user-input\",\r\n OAnimation: \"-o-animation\",\r\n OAnimationDelay: \"-o-animation-delay\",\r\n OAnimationDirection: \"-o-animation-direction\",\r\n OAnimationDuration: \"-o-animation-duration\",\r\n OAnimationFillMode: \"-o-animation-fill-mode\",\r\n OAnimationIterationCount: \"-o-animation-iteration-count\",\r\n OAnimationName: \"-o-animation-name\",\r\n OAnimationPlayState: \"-o-animation-play-state\",\r\n OAnimationTimingFunction: \"-o-animation-timing-function\",\r\n OBackgroundSize: \"-o-background-size\",\r\n OBorderImage: \"-o-border-image\",\r\n OObjectFit: \"-o-object-fit\",\r\n OObjectPosition: \"-o-object-position\",\r\n OTabSize: \"-o-tab-size\",\r\n OTextOverflow: \"-o-text-overflow\",\r\n OTransform: \"-o-transform\",\r\n OTransformOrigin: \"-o-transform-origin\",\r\n OTransition: \"-o-transition\",\r\n OTransitionDelay: \"-o-transition-delay\",\r\n OTransitionDuration: \"-o-transition-duration\",\r\n OTransitionProperty: \"-o-transition-property\",\r\n OTransitionTimingFunction: \"-o-transition-timing-function\",\r\n WebkitBoxAlign: \"-webkit-box-align\",\r\n WebkitBoxDirection: \"-webkit-box-direction\",\r\n WebkitBoxFlex: \"-webkit-box-flex\",\r\n WebkitBoxFlexGroup: \"-webkit-box-flex-group\",\r\n WebkitBoxLines: \"-webkit-box-lines\",\r\n WebkitBoxOrdinalGroup: \"-webkit-box-ordinal-group\",\r\n WebkitBoxOrient: \"-webkit-box-orient\",\r\n WebkitBoxPack: \"-webkit-box-pack\",\r\n WebkitScrollSnapPointsX: \"-webkit-scroll-snap-points-x\",\r\n WebkitScrollSnapPointsY: \"-webkit-scroll-snap-points-y\",\r\n //#endregion\r\n ////////////////////////////////////////////////////////////////////////////////////////////\r\n // #region SvgProperties\r\n alignmentBaseline: \"alignment-baseline\",\r\n baselineShift: \"baseline-shift\",\r\n clipRule: \"clip-rule\",\r\n colorInterpolation: \"color-interpolation\",\r\n colorRendering: \"color-rendering\",\r\n dominantBaseline: \"dominant-baseline\",\r\n fill: \"fill\",\r\n fillOpacity: \"fill-opacity\",\r\n fillRule: \"fill-rule\",\r\n floodColor: \"flood-color\",\r\n floodOpacity: \"flood-opacity\",\r\n glyphOrientationVertical: \"glyph-orientation-vertical\",\r\n lightingColor: \"lighting-color\",\r\n marker: \"marker\",\r\n markerEnd: \"marker-end\",\r\n markerMid: \"marker-mid\",\r\n markerStart: \"marker-start\",\r\n shapeRendering: \"shape-rendering\",\r\n stopColor: \"stop-color\",\r\n stopOpacity: \"stop-opacity\",\r\n stroke: \"stroke\",\r\n strokeDasharray: \"stroke-dasharray\",\r\n strokeDashoffset: \"stroke-dashoffset\",\r\n strokeLinecap: \"stroke-linecap\",\r\n strokeLinejoin: \"stroke-linejoin\",\r\n strokeMiterlimit: \"stroke-miterlimit\",\r\n strokeOpacity: \"stroke-opacity\",\r\n strokeWidth: \"stroke-width\",\r\n textAnchor: \"text-anchor\",\r\n vectorEffect: \"vector-effect\",\r\n progressShadow: \"--progress-shadow\",\r\n //#endregion\r\n\r\n //#region svg\r\n d: \"d\",\r\n //#endregion\r\n};\r\n//#endregion\r\n\r\n//#region Pseudo\r\nexport const objCssPseudoClasses = {\r\n //#region Element display state pseudo-classes\r\n \"&fullscreen\": \"fullscreen\",\r\n \"&modal\": \"modal\",\r\n \"&picture-in-picture\": \"picture-in-picture\",\r\n //#endregion\r\n ////////////////////////////////////////////////////////////////////////////////////////////\r\n //#region Input pseudo-classes\r\n \"&autofill\": \"autofill\",\r\n \"&enabled\": \"enabled\",\r\n \"&disabled\": \"disabled\",\r\n \"&read-only\": \"read-only\",\r\n \"&read-write\": \"read-write\",\r\n \"&placeholder-shown\": \"placeholder-shown\",\r\n \"&placeholderShown\": \"placeholder-shown\", //not stander\r\n \"¬PlaceholderShown\": \"not(:placeholder-shown)\", //not stander\r\n \"&default\": \"default\",\r\n \"&checked\": \"checked\",\r\n \"&indeterminate\": \"indeterminate\",\r\n \"&blank\": \"blank\",\r\n \"&valid\": \"valid\",\r\n \"&invalid\": \"invalid\",\r\n \"&in-range\": \"in-range\",\r\n \"&out-of-range\": \"out-of-range\",\r\n \"&required\": \"required\",\r\n \"&optional\": \"optional\",\r\n \"&user-valid\": \"user-valid\",\r\n //#endregion\r\n ////////////////////////////////////////////////////////////////////////////////////////////\r\n //#region Linguistic pseudo-classes\r\n /**\r\n * @deprecated\r\n */\r\n \"&lang\": \"lang\", //not stander\r\n //#endregion\r\n ////////////////////////////////////////////////////////////////////////////////////////////\r\n //#region Location pseudo-classes\r\n \"&any-link\": \"any-link\",\r\n \"&link\": \"link\",\r\n \"&visited\": \"visited\",\r\n \"&local-link\": \"local-link\",\r\n \"&target\": \"target\",\r\n \"&target-within\": \"target-within\",\r\n \"&scope\": \"scope\",\r\n //#endregion\r\n ////////////////////////////////////////////////////////////////////////////////////////////\r\n //#region Resource state pseudo-classes\r\n \"&playing\": \"playing\",\r\n \"&paused\": \"paused\",\r\n //#endregion\r\n ////////////////////////////////////////////////////////////////////////////////////////////\r\n //#region Time-dimensional pseudo-classes\r\n \"¤t\": \"current\",\r\n \"&past\": \"past\",\r\n \"&future\": \"future\",\r\n //#endregion\r\n ////////////////////////////////////////////////////////////////////////////////////////////\r\n //#region Tree-structural pseudo-classes\r\n \"&root\": \"root\",\r\n \"&empty\": \"empty\",\r\n \"¬Empty\": `not(:empty)`, //not stander\r\n \"&nth-child\": \"nth-child\",\r\n \"&nth-last-child\": \"nth-last-child\",\r\n \"&first-child\": \"first-child\",\r\n \"&last-child\": \"last-child\",\r\n \"&only-child\": \"only-child\",\r\n \"&nth-of-type\": \"nth-of-type\",\r\n \"&nth-last-of-type\": \"nth-last-of-type\",\r\n \"&first-of-type\": \"first-of-type\",\r\n \"&second-of-type\": \"nth-of-type(2)\", //not stander\r\n \"&third-of-type\": \"nth-of-type(3)\", //not stander\r\n \"&fourth-of-type\": \"nth-of-type(4)\", //not stander\r\n \"&last-of-type\": \"last-of-type\",\r\n \"&only-of-type\": \"only-of-type\",\r\n //#endregion\r\n ////////////////////////////////////////////////////////////////////////////////////////////\r\n //#region User action pseudo-classes\r\n \"&hover\": \"hover\",\r\n \"&blur\": \"not(:focus)\", //not stander\r\n \"&active\": \"active\",\r\n \"&focus\": \"focus\",\r\n \"&focus-visible\": \"focus-visible\",\r\n \"&focus-within\": \"focus-within\",\r\n //#endregion\r\n};\r\n\r\nexport const objCssPseudoElements = {\r\n \"&after\": \"after\",\r\n \"&backdrop\": \"backdrop\",\r\n \"&before\": \"before\",\r\n \"&cue\": \"cue\",\r\n \"&file-selector-button\": \"file-selector-button\",\r\n \"&first-letter\": \"first-letter\",\r\n \"&first-line\": \"first-line\",\r\n \"&grammar-error\": \"grammar-error\",\r\n \"&marker\": \"marker\",\r\n \"&placeholder\": \"placeholder\",\r\n \"&selection\": \"selection\",\r\n \"&spelling-error\": \"spelling-error\",\r\n \"&view-transition\": \"view-transition\",\r\n\r\n \"&WebkitSliderRunnableTrack\": \"-webkit-slider-runnable-track\",\r\n \"&WebkitSliderThumb\": \"-webkit-slider-thumb\",\r\n \"&MozRangeTrack\": \"-moz-range-track\",\r\n \"&MozRangeThumb\": \"-moz-range-thumb\",\r\n \"&MozRangeProgress\": \"-moz-range-progress\",\r\n};\r\n\r\nexport const objCssSymbols = {\r\n \"&*\": \"*\",\r\n \"&>\": \">\",\r\n \"&+\": \"+\",\r\n \"&~\": \"~\",\r\n \"¬\": \":not\",\r\n};\r\n//#endregion\r\n\r\n//#region HtmlJxsElement\r\nexport const objCssHtmlJxsElement = {\r\n body: \"body\",\r\n label: \"label\",\r\n input: \"input\",\r\n span: \"span\",\r\n div: \"div\",\r\n fieldset: \"fieldset\",\r\n legend: \"legend\",\r\n path: \"path\",\r\n};\r\n//#endregion\r\n\r\n//#region css Entities\r\nexport const objCSSEntities = {\r\n \"&rangle\": \"❯\",\r\n \"&langle\": \"❮\",\r\n};\r\n//#endregion\r\n\r\n//#region screen size\r\nexport const objScreenSize = {\r\n xs: xsScrSize,\r\n sm: smScrSize,\r\n md: mdScrSize,\r\n lg: lgScrSize,\r\n xl: xlScrSize,\r\n};\r\n\r\n//#endregion\r\n\r\nexport const defaultApply = {\r\n \"@apply\": true,\r\n};\r\n","export default{\r\n text: \"text\",\r\n font:\"font\",\r\n break:\"break\",\r\n \r\n border:\"border\",\r\n rounded:\"rounded\",\r\n\r\n width:\"w\",\r\n height:\"h\",\r\n max:\"max\",\r\n min:\"min\",\r\n}","export const keysPosition={\r\n relative:\"relative\",\r\n absolute:\"absolute\",\r\n fixed:\"fixed\",\r\n sticky:\"sticky\",\r\n\r\n X:\"x\",\r\n y:\"y\",\r\n t:\"top\",\r\n b:\"bottom\",\r\n r:\"right\",\r\n l:\"left\",\r\n inset:\"inset\",\r\n\r\n px:\"px\",\r\n auto:\"auto\",\r\n\r\n xs:\"xs\",\r\n sm:\"sm\",\r\n md:\"md\",\r\n lg:\"lg\",\r\n xl:\"xl\",\r\n\r\n \"1/2\":\"1/2\",\r\n \"1/3\":\"1/3\",\r\n \"2/3\":\"2/3\",\r\n \"1/4\":\"1/4\",\r\n \"2/4\":\"2/4\",\r\n \"3/4\":\"3/4\",\r\n \"1/5\":\"1/5\",\r\n \"2/5\":\"2/5\",\r\n \"3/5\":\"3/5\",\r\n \"4/5\":\"4/5\",\r\n\r\n \"1/6\":\"1/6\",\r\n \"2/6\":\"2/6\",\r\n \"3/6\":\"3/6\",\r\n \"4/6\":\"4/6\",\r\n \"5/6\":\"5/6\",\r\n\r\n \"1/12\":\"1/12\",\r\n \"2/12\":\"2/12\",\r\n \"3/12\":\"3/12\",\r\n \"4/12\":\"4/12\",\r\n \"5/12\":\"5/12\",\r\n \"6/12\":\"6/12\",\r\n \"7/12\":\"7/12\",\r\n \"8/12\":\"8/12\",\r\n \"9/12\":\"9/12\",\r\n \"10/12\":\"10/12\",\r\n \"11/12\":\"11/12\",\r\n\r\n X:\"x\",\r\n y:\"y\",\r\n t:\"t\",\r\n b:\"b\",\r\n r:\"r\",\r\n l:\"l\",\r\n}\r\n\r\nexport default{\r\n posVal:{\r\n [keysPosition?.relative]:\"relative\",\r\n [keysPosition?.absolute]:\"absolute\",\r\n [keysPosition?.fixed]:\"fixed\",\r\n [keysPosition?.sticky]:\"sticky\",\r\n },\r\n size:{\r\n [keysPosition?.px]:\"1px\",\r\n [keysPosition?.auto]:\"auto\",\r\n\r\n \r\n [keysPosition?.xs]:\".5rem\",\r\n [keysPosition?.sm]:\"1rem\",\r\n [keysPosition?.md]:\"1.5rem\",\r\n [keysPosition?.lg]:\"3rem\",\r\n [keysPosition?.xl]:\"5rem\",\r\n\r\n [keysPosition?.[\"1/2\"]]:\"50%\",\r\n [keysPosition?.[\"1/3\"]]:\"33.333333%\",\r\n [keysPosition?.[\"2/3\"]]:\"66.666667%\",\r\n [keysPosition?.[\"1/4\"]]:\"25%\",\r\n [keysPosition?.[\"2/4\"]]:\"50%\",\r\n [keysPosition?.[\"3/4\"]]:\"75%\",\r\n [keysPosition?.[\"1/5\"]]:\"20%\",\r\n [keysPosition?.[\"2/5\"]]:\"40%\",\r\n [keysPosition?.[\"3/5\"]]:\"60%\",\r\n [keysPosition?.[\"4/5\"]]:\"80%\",\r\n [keysPosition?.[\"1/6\"]]:\"16.666667%\",\r\n [keysPosition?.[\"2/6\"]]:\"33.333333%\",\r\n [keysPosition?.[\"3/6\"]]:\"50%\",\r\n [keysPosition?.[\"4/6\"]]:\"66.666667%\",\r\n [keysPosition?.[\"5/6\"]]:\"83.333333%\",\r\n\r\n [keysPosition?.[\"1/12\"]]:\"8.333333%\",\r\n [keysPosition?.[\"2/12\"]]:\"16.666667%\",\r\n [keysPosition?.[\"3/12\"]]:\"25%\",\r\n [keysPosition?.[\"4/12\"]]:\"33.333333%\",\r\n [keysPosition?.[\"5/12\"]]:\"41.666667%\",\r\n [keysPosition?.[\"6/12\"]]:\"50%\",\r\n [keysPosition?.[\"7/12\"]]:\"58.333333%\",\r\n [keysPosition?.[\"8/12\"]]:\"66.666667%\",\r\n [keysPosition?.[\"9/12\"]]:\"75%\",\r\n [keysPosition?.[\"10/12\"]]:\"83.333333%\",\r\n [keysPosition?.[\"11/12\"]]:\"91.666667%\",\r\n\r\n\r\n baseSize: 0.25,\r\n\r\n },\r\n side:{\r\n X:\"x\",\r\n y:\"y\",\r\n t:\"top\",\r\n b:\"bottom\",\r\n r:\"right\",\r\n l:\"left\",\r\n inset:\"inset\"\r\n }\r\n}","export const keysShadow={\r\n shadow:\"shadow\",\r\n xl2:\"2xl\",\r\n xl:\"xl\",\r\n lg:\"lg\",\r\n md:\"md\",\r\n sm:\"sm\",\r\n xs:\"xs\",\r\n inner:\"inner\",\r\n outline:\"outline\",\r\n none:\"none\"\r\n}\r\nexport default{\r\n [keysShadow?.shadow]:\"0 1px 3px 0 rgba(0, 0, 0, 0.1), 0 1px 2px 0 rgba(0, 0, 0, 0.06)\",\r\n [keysShadow?.inner]:\"inset 0 2px 4px 0 rgba(0, 0, 0, 0.06)\",\r\n [keysShadow?.outline]:\"0 0 0 3px rgba(0, 0, 0, 0.5)\",\r\n [keysShadow?.none]:\"none\",\r\n [keysShadow?.xl2]:\"0 25px 50px -12px rgba(0, 0, 0, 0.25)\",\r\n [keysShadow?.xl]:\"0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04)\",\r\n [keysShadow?.lg]:\"0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05)\",\r\n [keysShadow?.md]:\"0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06)\",\r\n [keysShadow?.sm]:\"0 1px 2px 0 rgba(0, 0, 0, 0.05)\",\r\n [keysShadow?.xs]:\"0 0 0 1px rgba(0, 0, 0, 0.05)\",\r\n}","import { baseSize } from \"../../cssVariable/cssVariable\"\r\n\r\nexport const keysSize={\r\n width:\"w\",\r\n height:\"h\",\r\n min:\"min\",\r\n max:\"max\",\r\n\r\n px:\"px\",\r\n auto:\"auto\",\r\n full:\"full\",\r\n half:\"half\",\r\n screen:\"screen\",\r\n\r\n xs:\"xs\",\r\n sm:\"sm\",\r\n md:\"md\",\r\n lg:\"lg\",\r\n xl:\"xl\",\r\n\r\n item_xs:\"item_xs\",\r\n item_sm:\"item_sm\",\r\n item_md:\"item_md\",\r\n item_lg:\"item_lg\",\r\n item_xl:\"item_xl\",\r\n\r\n \"1/2\":\"1/2\",\r\n \"1/3\":\"1/3\",\r\n \"2/3\":\"2/3\",\r\n \"1/4\":\"1/4\",\r\n \"2/4\":\"2/4\",\r\n \"3/4\":\"3/4\",\r\n \"1/5\":\"1/5\",\r\n \"2/5\":\"2/5\",\r\n \"3/5\":\"3/5\",\r\n \"4/5\":\"4/5\",\r\n\r\n \"1/6\":\"1/6\",\r\n \"2/6\":\"2/6\",\r\n \"3/6\":\"3/6\",\r\n \"4/6\":\"4/6\",\r\n \"5/6\":\"5/6\",\r\n\r\n \"1/12\":\"1/12\",\r\n \"2/12\":\"2/12\",\r\n \"3/12\":\"3/12\",\r\n \"4/12\":\"4/12\",\r\n \"5/12\":\"5/12\",\r\n \"6/12\":\"6/12\",\r\n \"7/12\":\"7/12\",\r\n \"8/12\":\"8/12\",\r\n \"9/12\":\"9/12\",\r\n \"10/12\":\"10/12\",\r\n \"11/12\":\"11/12\",\r\n}\r\n\r\nexport default{\r\n size:{\r\n [keysSize?.px]:\"1px\",\r\n [keysSize?.auto]:\"auto\",\r\n [keysSize?.full]:\"100%\",\r\n [keysSize?.half]:\"50%\",\r\n [keysSize?.screen]:\"100v\",\r\n\r\n [keysSize?.xs]:\"25%\",\r\n [keysSize?.sm]:\"41.666667%\",\r\n [keysSize?.md]:\"58.333333%\",\r\n [keysSize?.lg]:\"75%\",\r\n [keysSize?.xl]:\"91.666667%\",\r\n\r\n [keysSize?.item_xs]:`${baseSize * 6}rem`,\r\n [keysSize?.item_sm]:`${baseSize * 8}rem`,\r\n [keysSize?.item_md]:`${baseSize * 10}rem`,\r\n [keysSize?.item_lg]:`${baseSize * 12}rem`,\r\n [keysSize?.item_xl]:`${baseSize * 15}rem`,\r\n\r\n [keysSize?.[\"1/2\"]]:\"50%\",\r\n [keysSize?.[\"1/3\"]]:\"33.333333%\",\r\n [keysSize?.[\"2/3\"]]:\"66.666667%\",\r\n [keysSize?.[\"1/4\"]]:\"25%\",\r\n [keysSize?.[\"2/4\"]]:\"50%\",\r\n [keysSize?.[\"3/4\"]]:\"75%\",\r\n [keysSize?.[\"1/5\"]]:\"20%\",\r\n [keysSize?.[\"2/5\"]]:\"40%\",\r\n [keysSize?.[\"3/5\"]]:\"60%\",\r\n [keysSize?.[\"4/5\"]]:\"80%\",\r\n [keysSize?.[\"1/6\"]]:\"16.666667%\",\r\n [keysSize?.[\"2/6\"]]:\"33.333333%\",\r\n [keysSize?.[\"3/6\"]]:\"50%\",\r\n [keysSize?.[\"4/6\"]]:\"66.666667%\",\r\n [keysSize?.[\"5/6\"]]:\"83.333333%\",\r\n\r\n [keysSize?.[\"1/12\"]]:\"8.333333%\",\r\n [keysSize?.[\"2/12\"]]:\"16.666667%\",\r\n [keysSize?.[\"3/12\"]]:\"25%\",\r\n [keysSize?.[\"4/12\"]]:\"33.333333%\",\r\n [keysSize?.[\"5/12\"]]:\"41.666667%\",\r\n [keysSize?.[\"6/12\"]]:\"50%\",\r\n [keysSize?.[\"7/12\"]]:\"58.333333%\",\r\n [keysSize?.[\"8/12\"]]:\"66.666667%\",\r\n [keysSize?.[\"9/12\"]]:\"75%\",\r\n [keysSize?.[\"10/12\"]]:\"83.333333%\",\r\n [keysSize?.[\"11/12\"]]:\"91.666667%\",\r\n },\r\n}","export const keysSpacing={\r\n start: \"start\",\r\n end:\"end\",\r\n\r\n px:\"px\",\r\n auto:\"auto\",\r\n\r\n mrg:\"m\",\r\n mrgTop:\"mt\",\r\n mrgBottom:\"mb\",\r\n mrgLeft:\"ml\",\r\n mrgRight:\"mr\",\r\n mrgY:\"my\",\r\n mrgX:\"mx\",\r\n\r\n xs:\"xs\",\r\n sm:\"sm\",\r\n md:\"md\",\r\n lg:\"lg\",\r\n xl:\"xl\",\r\n\r\n pdn:\"p\",\r\n pdnTop:\"pt\",\r\n pdnBottom:\"pb\",\r\n pdnLeft:\"pl\",\r\n pdnRight:\"pr\",\r\n pdnY:\"py\",\r\n pdnX:\"px\",\r\n}\r\n\r\nexport default{\r\n spacing:{\r\n [keysSpacing?.px]:\"1px\",\r\n [keysSpacing?.auto]:\"auto\",\r\n\r\n [keysSpacing?.xs]:\".5rem\",\r\n [keysSpacing?.sm]:\"1rem\",\r\n [keysSpacing?.md]:\"1.3rem\",\r\n [keysSpacing?.lg]:\"2.6rem\",\r\n [keysSpacing?.xl]:\"5rem\",\r\n\r\n baseSize: 0.25,\r\n\r\n }\r\n}","import colorGradientName from \"./colorGradientName\"\r\n\r\n// let HEX = /^#([a-f\\d]{2})([a-f\\d]{2})([a-f\\d]{2})([a-f\\d]{2})?$/i\r\n// let SHORT_HEX = /^#([a-f\\d])([a-f\\d])([a-f\\d])([a-f\\d])?$/i\r\n// let VALUE = /(?:\\d+|\\d*\\.\\d+)%?/\r\n// let SEP = /(?:\\s*,\\s*|\\s+)/\r\n// let ALPHA_SEP = /\\s*[,/]\\s*/\r\n// let CUSTOM_PROPERTY = /var\\(--(?:[^ )]*?)(?:,(?:[^ )]*?|var\\(--[^ )]*?\\)))?\\)/\r\n\r\n\r\n// let RGB = new RegExp(\r\n// `^(rgba?)\\\\(\\\\s*(${VALUE.source}|${CUSTOM_PROPERTY.source})(?:${SEP.source}(${VALUE.source}|${CUSTOM_PROPERTY.source}))?(?:${SEP.source}(${VALUE.source}|${CUSTOM_PROPERTY.source}))?(?:${ALPHA_SEP.source}(${VALUE.source}|${CUSTOM_PROPERTY.source}))?\\\\s*\\\\)$`\r\n// )\r\n// let HSL = new RegExp(\r\n// `^(hsla?)\\\\(\\\\s*((?:${VALUE.source})(?:deg|rad|grad|turn)?|${CUSTOM_PROPERTY.source})(?:${SEP.source}(${VALUE.source}|${CUSTOM_PROPERTY.source}))?(?:${SEP.source}(${VALUE.source}|${CUSTOM_PROPERTY.source}))?(?:${ALPHA_SEP.source}(${VALUE.source}|${CUSTOM_PROPERTY.source}))?\\\\s*\\\\)$`\r\n// )\r\n\r\nexport const returnColor = (arrCssValue)=>{\r\n if(arrCssValue.length===3){\r\n return colorGradientName?.[arrCssValue[1]]?.[arrCssValue[2]]\r\n }else if(typeof colorGradientName?.[arrCssValue[1]] === \"string\"){\r\n return colorGradientName?.[arrCssValue[1]]\r\n }else if(typeof colorGradientName?.[arrCssValue[1]] === \"object\"){\r\n return colorGradientName?.[arrCssValue[1]]?.[\"500\"]\r\n }else{\r\n return colorGradientName?.transparent\r\n }\r\n}\r\n\r\n// export function changeColorAlpha(color, opacity) \r\n// {\r\n// //if it has an alpha, remove it\r\n// if (color.length > 7)\r\n// color = color.substring(0, color.length - 2);\r\n\r\n// // coerce values so ti is between 0 and 1.\r\n// const _opacity = Math.round(Math.min(Math.max(opacity, 0), 1) * 255);\r\n// let opacityHex = _opacity.toString(16).toUpperCase()\r\n// }\r\n\r\n// function changeColorAlpha(color, opacity) \r\n// {\r\n// //if it has an alpha, remove it\r\n// if (color.length > 7)\r\n// color = color.substring(0, color.length - 2);\r\n\r\n// // coerce values so ti is between 0 and 1.\r\n// const _opacity = Math.round(Math.min(Math.max(opacity, 0), 1) * 255);\r\n// let opacityHex = _opacity.toString(16).toUpperCase()\r\n\r\n// // opacities near 0 need a trailing 0\r\n// if (opacityHex.length == 1)\r\n// opacityHex = \"0\" + opacityHex;\r\n\r\n// return color + opacityHex;\r\n// }\r\n// function rgb2hex(rgb, rgba){\r\n// rgb = rgb.match(/^rgb?[\\s+]?\\([\\s+]?(\\d+)[\\s+]?,[\\s+]?(\\d+)[\\s+]?,[\\s+]?(\\d+)[\\s+]?/i);\r\n// rgba = rgba.match(/^rgba?\\((\\d+),\\s*(\\d+),\\s*(\\d+)(?:,\\s*(\\d+(?:\\.\\d+)?))?\\)$/)\r\n\r\n// var red = Math.round((rgba[1] * rgba[4]) + (rgb[1] * (1-rgba[4])));\r\n// var blue = Math.round((rgba[2] * rgba[4]) + (rgb[2] * (1-rgba[4])));\r\n// var green = Math.round((rgba[3] * rgba[4]) + (rgb[3] * (1-rgba[4]))); \r\n// return (rgba && rgba.length === 5) ? \"#\" +\r\n// (\"0\" + red.toString(16)).slice(-2) +\r\n// (\"0\" + blue.toString(16)).slice(-2) +\r\n// (\"0\" + green.toString(16)).slice(-2) : '';\r\n// }","export const keysBG={\r\n size:\"size\",\r\n position:\"position\",\r\n attachment:\"attachment\",\r\n repeat:\"repeat\",\r\n clip:\"clip\",\r\n opacity:\"opacity\", //bg-opacity-value (%)\r\n none:\"none\" //bg-none\r\n}\r\n\r\nexport default{\r\n [keysBG?.size]:{ //bg-value\r\n cover:\"cover\",\r\n contain:\"contain\",\r\n auto:\"auto\",\r\n },\r\n [keysBG?.position]:{ // bg-v-value-h-value\r\n cover:\"top\",\r\n contain:\"bottom\",\r\n center:\"center\",\r\n left: \"left\",\r\n \"right\":\"right\"\r\n },\r\n [keysBG?.attachment]:{ //bg-value\r\n fixed:\"fixed\",\r\n local:\"local\",\r\n scroll:\"scroll\"\r\n },\r\n [keysBG?.repeat]:{//bg-repeat || bg-repeat-value || bg-no-repeat\r\n repeat:\"repeat\",\r\n no:\"no-repeat\",\r\n x:\"repeat-x\",\r\n y:\"repeat-y\",\r\n round:\"round\",\r\n space:\"space\",\r\n },\r\n [keysBG?.clip]:{//bg-clip-value\r\n border:\"border-box\",\r\n content:\"content-box\",\r\n padding:\"padding-box\",\r\n text:\"text\",\r\n }\r\n}","export const keysBorder={\r\n border:\"border\",\r\n divide:\"divide\",\r\n rounded:\"rounded\",\r\n borderSides:\"borderSides\"\r\n}\r\n\r\nexport default{\r\n [keysBorder?.border]:{ //bg-value\r\n solid:\"solid\",\r\n dashed:\"dashed\",\r\n dotted:\"dotted\",\r\n none:\"none\",\r\n },\r\n [keysBorder?.divide]:{ // bg-v-value-h-value\r\n },\r\n [keysBorder?.rounded]:{ //bg-value\r\n xs:\"0.25rem\",\r\n sm:\"0.5rem\",\r\n md:\".0.75rem\",\r\n lg:\"1rem\",\r\n xl:\"1.5rem\",\r\n pill:\"100%\",\r\n },\r\n [keysBorder?.borderSides]:{\r\n X:\"x\",\r\n y:\"y\",\r\n t:\"t\",\r\n b:\"b\",\r\n r:\"r\",\r\n l:\"l\",\r\n xs:\"xs\",\r\n ys:\"ys\",\r\n xe:\"xe\",\r\n ye:\"ye\",\r\n tr:\"tr\",\r\n tl:\"tl\",\r\n br:\"br\",\r\n bl:\"bl\",\r\n }\r\n}","export const keysText={\r\n text: \"text\",\r\n font:\"font\",\r\n break:\"break\",\r\n truncate:\"truncate\",\r\n transform:\"transform\",\r\n size:\"size\",\r\n\r\n\r\n\r\n}\r\n\r\nexport default{\r\n [keysText?.break]:{\r\n normal:\"normal\",\r\n words:\"break-word\",\r\n all:\"break-all\"\r\n },\r\n [keysText?.transform]:{\r\n \"uppercase\":\"uppercase\",\r\n \"lowercase\":\"lowercase\",\r\n \"capitalize\":\"capitalize\",\r\n \"normalcase\":\"none\",\r\n },\r\n [keysText?.size]:{\r\n h1:\"4rem\",\r\n h2:\"3rem\",\r\n h3:\"1.875rem\",\r\n h4:\"2.25rem\",\r\n h5:\"1.875rem\",\r\n h6:\"1.25rem\",\r\n subtitle1:\"1.125rem\",\r\n subtitle2:\"1.15rem\",\r\n body1:\"1rem\",\r\n body2:\".875rem\",\r\n caption:\".75rem\",\r\n overline:\".5rem\",\r\n\r\n baseSize: 0.25,\r\n\r\n }\r\n}","import { objCssProperties } from \"packages/style/src/helper/cssProperties\";\r\nimport keys, { keysSize } from \"./keys\";\r\n\r\nconst getSize=(arrClasses, key)=>{\r\n const size = arrClasses?.[2] || arrClasses?.[1]\r\n if(!isNaN(Number(size)) ){\r\n return `${keys?.size?.baseSize * Number(size)}rem`\r\n }else if(keysSize?.[size]){\r\n if(size === keysSize?.screen){\r\n return keys?.size?.[keysSize?.screen] + key\r\n }else{\r\n return keys?.size?.[keysSize?.[size]]\r\n }\r\n }\r\n}\r\n\r\nexport default (classesName)=>{\r\n const arrClasses = String(classesName)?.toLowerCase()?.split(\"-\");\r\n if(arrClasses?.[0] === keysSize?.width){\r\n return {[objCssProperties?.width] : getSize(arrClasses, keysSize?.width)}\r\n }else if(arrClasses?.[0] === keysSize?.max && arrClasses?.[1] === keysSize?.width){\r\n return {[objCssProperties?.maxWidth] : getSize(arrClasses, keysSize?.width)}\r\n }else if(arrClasses?.[0] === keysSize?.min && arrClasses?.[1] === keysSize?.width){\r\n return {[objCssProperties?.minWidth] : getSize(arrClasses, keysSize?.width)}\r\n }\r\n else if(arrClasses?.[0] === keysSize?.height){\r\n return {[objCssProperties?.height] : getSize(arrClasses, keysSize?.height)}\r\n }else if(arrClasses?.[0] === keysSize?.max && arrClasses?.[1] === keysSize?.height){\r\n return {[objCssProperties?.maxHeight] : getSize(arrClasses, keysSize?.height)}\r\n }else if(arrClasses?.[0] === keysSize?.min && arrClasses?.[1] === keysSize?.height){\r\n return {[objCssProperties?.minHeight] : getSize(arrClasses, keysSize?.height)}\r\n }\r\n}","import { objCssProperties } from \"packages/style/src/helper/cssProperties\";\r\nimport keys, { keysSpacing } from \"./keys\";\r\n\r\nconst getSpace=(arrClasses)=>{\r\n const spacer = arrClasses?.[2] || arrClasses?.[1]\r\n if(!isNaN(Number(spacer)) ){\r\n return `${keys?.spacer?.baseSize * Number(spacer)}rem`\r\n }else if(keysSpacing?.[spacer]){\r\n return keys?.spacer?.[keysSpacing?.[spacer]]\r\n }\r\n}\r\n\r\nexport default (classesName)=>{\r\n const arrClasses = String(classesName)?.toLowerCase()?.split(\"-\");\r\n const value = getSpace(arrClasses)\r\n if(arrClasses?.[0] === keysSpacing?.mrg){\r\n return {[objCssProperties?.margin] : value}\r\n }else if(arrClasses?.[0] === keysSpacing?.mrgTop){\r\n return {[objCssProperties?.marginTop] : value}\r\n }else if(arrClasses?.[0] === keysSpacing?.mrgBottom){\r\n return {[objCssProperties?.marginBottom] : value}\r\n }else if(arrClasses?.[0] === keysSpacing?.mrgLeft){\r\n return {[objCssProperties?.marginLeft] : value}\r\n }else if(arrClasses?.[0] === keysSpacing?.mrgRight){\r\n return {[objCssProperties?.marginRight] : value}\r\n }else if(arrClasses?.[0] === keysSpacing?.mrgX){\r\n return {\r\n [objCssProperties?.marginRight] : value,\r\n [objCssProperties?.marginLeft] : value\r\n }\r\n }else if(arrClasses?.[0] === keysSpacing?.mrgY){\r\n return {\r\n [objCssProperties?.marginTop] : value,\r\n [objCssProperties?.marginBottom] : value\r\n }\r\n }else if( arrClasses?.[0] === keysSpacing?.start && arrClasses?.[1] === keysSpacing?.mrgX){\r\n return {[objCssProperties?.marginInlineStart] : value,}\r\n }else if( arrClasses?.[0] === keysSpacing?.end && arrClasses?.[1] === keysSpacing?.mrgX){\r\n return {[objCssProperties?.marginInlineEnd] : value,}\r\n }else if( arrClasses?.[0] === keysSpacing?.start && arrClasses?.[1] === keysSpacing?.mrgY){\r\n return {[objCssProperties?.marginBlockStart] : value,}\r\n }else if( arrClasses?.[0] === keysSpacing?.end && arrClasses?.[1] === keysSpacing?.mrgY){\r\n return {[objCssProperties?.marginBlockEnd] : value,}\r\n }\r\n else if(arrClasses?.[0] === keysSpacing?.pdn){\r\n return {[objCssProperties?.padding] : value}\r\n }else if(arrClasses?.[0] === keysSpacing?.pdnTop){\r\n return {[objCssProperties?.paddingTop] : value}\r\n }else if(arrClasses?.[0] === keysSpacing?.pdnBottom){\r\n return {[objCssProperties?.paddingBottom] : value}\r\n }else if(arrClasses?.[0] === keysSpacing?.pdnLeft){\r\n return {[objCssProperties?.paddingLeft] : value}\r\n }else if(arrClasses?.[0] === keysSpacing?.pdnRight){\r\n return {[objCssProperties?.paddingRight] : value}\r\n }else if(arrClasses?.[0] === keysSpacing?.pdnX){\r\n return {\r\n [objCssProperties?.paddingRight] : value,\r\n [objCssProperties?.paddingLeft] : value\r\n }\r\n }else if(arrClasses?.[0] === keysSpacing?.pdnY){\r\n return {\r\n [objCssProperties?.paddingTop] : value,\r\n [objCssProperties?.paddingBottom] : value\r\n }\r\n }else if( arrClasses?.[0] === keysSpacing?.start && arrClasses?.[1] === keysSpacing?.pdnX){\r\n return {[objCssProperties?.paddingInlineStart] : value,}\r\n }else if( arrClasses?.[0] === keysSpacing?.end && arrClasses?.[1] === keysSpacing?.pdnX){\r\n return {[objCssProperties?.paddingInlineEnd] : value,}\r\n }else if( arrClasses?.[0] === keysSpacing?.start && arrClasses?.[1] === keysSpacing?.pdnY){\r\n return {[objCssProperties?.paddingBlockStart] : value,}\r\n }else if( arrClasses?.[0] === keysSpacing?.end && arrClasses?.[1] === keysSpacing?.pdnY){\r\n return {[objCssProperties?.paddingBlockEnd] : value,}\r\n }\r\n\r\n}","import { objCssProperties } from \"packages/style/src/helper/cssProperties\";\r\nimport keys, { keysPosition } from \"./keys\";\r\n\r\nconst getPosSize=(arrClasses, key)=>{\r\n const size = arrClasses?.[1]\r\n if(!isNaN(Number(size)) ){\r\n return `${keys?.size?.baseSize * Number(size)}rem`\r\n }else if(keysPosition?.[size]){\r\n return keys?.size?.[keysPosition?.[size]]\r\n }\r\n}\r\n\r\nexport default (classesName)=>{\r\n const arrClasses = String(classesName)?.toLowerCase()?.split(\"-\");\r\n const value = getPosSize(arrClasses)\r\n if(keys?.posVal?.[arrClasses?.[0]]){\r\n return {[objCssProperties?.position] : arrClasses?.[0]}\r\n }else if(arrClasses?.[0] === keys?.side?.y){\r\n return {\r\n [objCssProperties?.top] : value,\r\n [objCssProperties?.bottom] : value\r\n }\r\n }else if(arrClasses?.[0] === keys?.side?.x){\r\n return {\r\n [objCssProperties?.left] : value,\r\n [objCssProperties?.right] : value\r\n }\r\n }else if(arrClasses?.[0] === keys?.side?.inset){\r\n return {\r\n [objCssProperties?.left] : value,\r\n [objCssProperties?.right] : value,\r\n [objCssProperties?.top] : value,\r\n [objCssProperties?.bottom] : value,\r\n }\r\n }else if(keys?.side?.[arrClasses?.[0]]){\r\n return {\r\n [objCssProperties?.[keys?.side?.[arrClasses?.[0]]]] : value,\r\n }\r\n }\r\n}","\r\nimport formatKeysValue from \"./formatKeysValue\";\r\nimport { keysPosition } from \"./position/keys\";\r\nimport { keysShadow } from \"./shadow/keys\";\r\nimport { keysSize } from \"./sizing/keys\";\r\nimport { keysSpacing } from \"./spacing/keys\";\r\n\r\nimport background from \"./background/background\";\r\nimport border from \"./border/border\";\r\nimport text from \"./text/text\";\r\nimport sizing from \"./sizing/sizing\";\r\nimport spacing from \"./spacing/spacing\";\r\nimport position from \"./position/position\";\r\nimport shadow from \"./shadow/shadow\";\r\n\r\nexport default (classesName)=>{\r\n \"rule-value1-value2\"\r\n const arrCssValue = String(classesName)?.toLowerCase()?.split(\"-\")\r\n\r\n if(arrCssValue[0] === formatKeysValue?.background){\r\n return background(classesName)\r\n }else if(arrCssValue[0] === formatKeysValue?.border || arrCssValue[0] === formatKeysValue?.rounded){\r\n return border(classesName)\r\n }else if(arrCssValue[0] === formatKeysValue?.text || arrCssValue[0] === formatKeysValue?.font || arrCssValue[0] === formatKeysValue?.break){\r\n return text(classesName)\r\n }else if(arrCssValue[0] === keysSize?.width || arrCssValue[0] === keysSize?.height || arrCssValue[1] === keysSize?.width || arrCssValue[2] === keysSize?.height){\r\n return sizing(classesName)\r\n }else if(String(arrCssValue[0]).charAt(0) === keysSpacing?.mrg || String(arrCssValue[0]).charAt(0) === keysSpacing?.pdn){\r\n return spacing(classesName)\r\n }else if(keysPosition?.[arrCssValue?.[0]]){\r\n return position(classesName)\r\n }else if(arrCssValue?.[0] === keysShadow?.shadow){\r\n return shadow(classesName)\r\n }\r\n}","import { objCssProperties } from \"packages/style/src/helper/cssProperties\";\r\nimport { returnColor } from \"../color/color\";\r\nimport keys, { keysBG } from \"./keys\";\r\n\r\nexport default (classesName)=>{\r\n const arrClasses = String(classesName)?.toLowerCase()?.split(\"-\");\r\n if(arrClasses?.[1] === keysBG?.none){\r\n return {[objCssProperties?.backgroundImage] : keysBG?.none}\r\n }else if(arrClasses?.[1] === keysBG?.repeat){\r\n if(arrClasses?.length === 2){\r\n return {[`${objCssProperties?.background}-${keysBG?.repeat}`] : keys?.[keysBG?.repeat]?.repeat}\r\n }else if(arrClasses?.length === 3){\r\n return {[`${objCssProperties?.background}-${keysBG?.repeat}`] : keys?.[keysBG?.repeat]?.[arrClasses?.[2]]}\r\n }\r\n }else if(arrClasses?.[1] === \"no\"){\r\n return {[`${objCssProperties?.background}-${keysBG?.repeat}`] : keys?.[keysBG?.repeat]?.no}\r\n }else if(arrClasses?.[1] === keysBG?.opacity){\r\n return {[keysBG?.opacity]: (Number(arrClasses?.[1]) / 100 ) || 1}\r\n }else if(keys?.[keysBG?.position]?.[arrClasses?.[1]]){\r\n if(arrClasses?.length === 2){\r\n return {[`${objCssProperties?.background}-${keysBG?.position}`] : keys?.[keysBG?.position]?.[arrClasses?.[1]]}\r\n }else if(arrClasses?.length === 3){\r\n return {[`${objCssProperties?.background}-${keysBG?.position}`] : `${keys?.[keysBG?.position]?.[arrClasses?.[1]]} ${keys?.[keysBG?.position]?.[arrClasses?.[2]]}` }\r\n }\r\n }else if(keys?.[keysBG?.size]?.[arrClasses?.[1]]){\r\n return {[`${objCssProperties?.background}-${keysBG?.size}`]: keys?.[keysBG?.size]?.[arrClasses?.[1]]}\r\n }else if(keys?.[keysBG?.attachment]?.[arrClasses?.[1]]){\r\n return {[`${objCssProperties?.background}-${keysBG?.attachment}`]: keys?.[keysBG?.attachment]?.[arrClasses?.[1]]}\r\n }else if(arrClasses?.[1] === keysBG?.clip){\r\n return {[`${objCssProperties?.background}-${keysBG?.clip}`]: keys?.[keysBG?.attachment]?.[arrClasses?.[2]]}\r\n }else{\r\n return {[objCssProperties?.backgroundColor] : returnColor(arrClasses)}\r\n\r\n }\r\n}","import { objCssProperties } from \"packages/style/src/helper/cssProperties\";\r\nimport { returnColor } from \"../color/color\";\r\nimport keys, { keysBorder } from \"./keys\";\r\nimport colorGradientName from \"../color/colorGradientName\";\r\n\r\nexport default (classesName)=>{\r\n const arrClasses = String(classesName)?.toLowerCase()?.split(\"-\");\r\n if(arrClasses?.[0] === keysBorder?.border && keys?.[keysBorder?.border]?.[arrClasses?.[1]]){\r\n return {[objCssProperties?.border] : `1px ${keys?.[keysBorder?.border]?.[arrClasses?.[1]]} ${colorGradientName?.gray?.[500]}`}\r\n }\r\n else if(arrClasses?.[0] === keysBorder?.border && !isNaN(Number(arrClasses?.[1]))){\r\n return {[objCssProperties?.borderWidth] : `${Number(arrClasses?.[1])}px`}\r\n }\r\n else if(arrClasses?.[0] === keysBorder?.rounded && keys?.[keysBorder?.rounded]?.[arrClasses?.[1]]){\r\n return {[objCssProperties?.borderRadius] : keys?.[keysBorder?.rounded]?.[arrClasses?.[1]] }\r\n }\r\n else{\r\n return {[objCssProperties?.borderColor] : returnColor(arrClasses)}\r\n }\r\n}\r\n\r\n// else if(arrClasses?.[0] === keysBorder?.border && keys?.[keysBorder?.borderSides]?.[arrClasses?.[1]] && keys?.[keysBorder?.border]?.[arrClasses?.[2]]){\r\n // return {[cssKeys?.border] : `1px ${keys?.[keysBorder?.border]?.[arrClasses?.[1]]} #222`}\r\n // }","import { objCssProperties } from \"packages/style/src/helper/cssProperties\";\r\nimport { returnColor } from \"../color/color\";\r\nimport keys, { keysText } from \"./keys\";\r\n\r\nexport default (classesName)=>{\r\n const arrClasses = String(classesName)?.toLowerCase()?.split(\"-\");\r\n if(arrClasses?.[0] === keysText?.text && keys?.[keysText?.size]?.[arrClasses?.[1]]){\r\n return { [objCssProperties?.fontSize] : keys?.[keysText?.size]?.[arrClasses?.[1]]}\r\n }else if(arrClasses?.[0] === keysText?.text && !isNaN(Number(arrClasses?.[1]))){\r\n return { [objCssProperties?.fontSize] : `${keys?.[keysText?.size]?.baseSize * Number(arrClasses?.[1])}rem`}\r\n }else if(arrClasses?.[0] === keysText?.break && arrClasses?.[1]){\r\n if(arrClasses?.[1] === keys?.[keysText?.break]?.normal){\r\n return {\r\n [objCssProperties?.wordBreak] : keys?.[keysText?.break]?.normal,\r\n [objCssProperties?.overflowWrap] : keys?.[keysText?.break]?.normal,\r\n }\r\n }else{\r\n return {[objCssProperties?.wordBreak] : keys?.[keysText?.break]?.[arrClasses?.[2]]}\r\n }\r\n }else if(arrClasses?.[1] === keysText?.truncate){\r\n return {\r\n [objCssProperties?.overflow] : \"hidden\",\r\n [objCssProperties?.textOverflow] : \"ellipsis\",\r\n [objCssProperties?.whiteSpace] : \"nowrap\"\r\n }\r\n }if(arrClasses?.[1] === keysText?.transform && arrClasses?.[2]){\r\n return { [objCssProperties?.textTransform] : keys?.[keysText?.transform]?.[arrClasses?.[2]]}\r\n }else{\r\n return {[objCssProperties?.color] : returnColor(arrClasses)}\r\n }\r\n}\r\n\r\n","import { objCssProperties } from \"packages/style/src/helper/cssProperties\";\r\nimport keys, { keysShadow } from \"./keys\";\r\n\r\nexport default (classesName)=>{\r\n const arrClasses = String(classesName)?.toLowerCase()?.split(\"-\");\r\n if(arrClasses?.length === 1){\r\n return {[objCssProperties?.boxShadow]: keys?.[keysShadow?.shadow]}\r\n }else if(arrClasses?.length === 2){\r\n return {[objCssProperties?.boxShadow]: keys?.[arrClasses?.[1]]}\r\n }\r\n}","import { getCacheStoreTrack, getCacheStyleSheetIndex } from \"../cache/MainCache\";\r\nimport { pkgConfigStyle } from \"..\";\r\nconst splitMedia = \"-|-\";\r\n\r\nexport async function cleanRule(idComp, blnIsDefaultStyle, blnCbmisStyle, appStyleConfig, _styleRef, _props, lstStyleClasses) {\r\n try {\r\n if (_styleRef?.blnInsertRun || !lstStyleClasses?.length) {\r\n return;\r\n }\r\n\r\n let styleRef = _styleRef || {};\r\n\r\n const objCache = getCacheStoreTrack(appStyleConfig, { blnCbmisStyle, blnIsDefaultStyle });\r\n\r\n for (let i = 0; i < lstStyleClasses.length; i++) {\r\n const mainCssClassName = styleRef?.objClassesNames?.[lstStyleClasses?.[i]?.[0]];\r\n if (!objCache.has(mainCssClassName)) {\r\n continue;\r\n }\r\n\r\n const objGroupClassNameInfo = objCache.get(mainCssClassName);\r\n\r\n if (objGroupClassNameInfo?.usage?.has(idComp)) {\r\n objGroupClassNameInfo?.usage?.delete(idComp);\r\n }\r\n\r\n if (objGroupClassNameInfo?.usage?.size) {\r\n continue;\r\n }\r\n\r\n if (!objGroupClassNameInfo?.objCss?.size && !objGroupClassNameInfo?.usage?.size) {\r\n objCache.delete(mainCssClassName);\r\n continue;\r\n }\r\n\r\n let from = 0;\r\n const entries = objGroupClassNameInfo.objCss.entries();\r\n for (const entry of entries) {\r\n if (_styleRef?.blnInsertRun || objGroupClassNameInfo?.usage?.size) {\r\n break;\r\n }\r\n if (!entry) {\r\n continue;\r\n }\r\n\r\n const [cssSelectors, { idx }] = entry;\r\n const indexStyle = getCacheStyleSheetIndex(appStyleConfig, { blnCbmisStyle, blnIsDefaultStyle });\r\n\r\n const cssRule = document?.styleSheets?.[indexStyle];\r\n for (let k = from; k < cssRule?.cssRules?.length; k++) {\r\n if (_styleRef?.blnInsertRun || objGroupClassNameInfo?.usage?.size) {\r\n break;\r\n }\r\n const objCurrentCssRule = cssRule.cssRules.item(k);\r\n\r\n if (objCurrentCssRule instanceof CSSMediaRule && cssSelectors.includes(\"@media\") && cssSelectors.includes(splitMedia)) {\r\n const [mediaType, selectorText] = cssSelectors.split(splitMedia);\r\n let objCSSStyleRule = objCurrentCssRule.cssRules?.length ? objCurrentCssRule?.cssRules?.item(0) : null;\r\n let strMediaListItem = objCurrentCssRule.media?.length ? objCurrentCssRule?.media?.item(0) : null;\r\n if (objCSSStyleRule && strMediaListItem && objCSSStyleRule instanceof CSSStyleRule && mediaType.includes(strMediaListItem) && objCSSStyleRule?.selectorText === selectorText) {\r\n cssRule.deleteRule(k);\r\n objGroupClassNameInfo.objCss.delete(cssSelectors);\r\n from = k;\r\n break;\r\n }\r\n }\r\n\r\n if (objCurrentCssRule instanceof CSSStyleRule && objCurrentCssRule?.selectorText === cssSelectors) {\r\n cssRule.deleteRule(k);\r\n objGroupClassNameInfo.objCss.delete(cssSelectors);\r\n from = k;\r\n break;\r\n }\r\n\r\n if (objCurrentCssRule instanceof CSSKeyframesRule && cssSelectors.includes(\"@keyframes\") && objCurrentCssRule?.cssText?.includes(cssSelectors)) {\r\n const [keyframes, animateName] = cssSelectors.split(\" \");\r\n if (animateName && objCurrentCssRule?.name === animateName) {\r\n cssRule.deleteRule(k);\r\n objGroupClassNameInfo.objCss.delete(cssSelectors);\r\n from = k;\r\n break;\r\n }\r\n }\r\n\r\n from = 0;\r\n }\r\n }\r\n\r\n if (!objGroupClassNameInfo?.objCss?.size && !objGroupClassNameInfo?.usage?.size) {\r\n objCache.delete(mainCssClassName);\r\n }\r\n }\r\n\r\n _styleRef.blnInsertRun = false;\r\n _styleRef.blnPatchRun = false;\r\n } catch (error) {\r\n if (pkgConfigStyle?.blnIsTestingMode) {\r\n console.warn(error);\r\n }\r\n }\r\n}\r\n\r\nexport async function cleanOne(idComp, blnIsDefaultStyle, blnCbmisStyle, appStyleConfig, strRuleClassName, strClientClassName) {\r\n try {\r\n const objCache = getCacheStoreTrack(appStyleConfig, { blnCbmisStyle, blnIsDefaultStyle });\r\n\r\n let [clientClassName, mainCssClassName] = [strClientClassName, strRuleClassName];\r\n if (!objCache.has(mainCssClassName)) {\r\n return;\r\n }\r\n const objGroupClassNameInfo = objCache.get(mainCssClassName);\r\n\r\n if (objGroupClassNameInfo?.usage?.has(idComp)) {\r\n objGroupClassNameInfo?.usage?.delete(idComp);\r\n }\r\n\r\n if (objGroupClassNameInfo?.usage?.size) {\r\n return;\r\n }\r\n\r\n if (!objGroupClassNameInfo?.objCss?.size && !objGroupClassNameInfo?.usage?.size) {\r\n objCache.delete(mainCssClassName);\r\n return;\r\n }\r\n\r\n let prevIdx = 0;\r\n let offset = 0;\r\n let from = 0;\r\n const entries = objGroupClassNameInfo.objCss.entries();\r\n for (const entry of entries) {\r\n if (objGroupClassNameInfo?.usage?.size) {\r\n break;\r\n }\r\n if (!entry) {\r\n continue;\r\n }\r\n\r\n const [cssSelectors, { idx }] = entry;\r\n const indexStyle = getCacheStyleSheetIndex(appStyleConfig, { blnCbmisStyle, blnIsDefaultStyle });\r\n const cssRule = document?.styleSheets?.[indexStyle];\r\n\r\n prevIdx = idx;\r\n if (prevIdx > 0 && offset > 0) {\r\n from = idx - (prevIdx - offset);\r\n from = from < 0 ? 0 : from >= cssRule?.cssRules?.length ? 0 : from;\r\n }\r\n for (let k = from; k < cssRule?.cssRules?.length; k++) {\r\n if (objGroupClassNameInfo?.usage?.size) {\r\n break;\r\n }\r\n const objCurrentCssRule = cssRule.cssRules.item(k);\r\n\r\n if (objCurrentCssRule instanceof CSSMediaRule && cssSelectors.includes(\"@media\") && cssSelectors.includes(splitMedia)) {\r\n const [mediaType, selectorText] = cssSelectors.split(splitMedia);\r\n let objCSSStyleRule = objCurrentCssRule.cssRules?.length ? objCurrentCssRule?.cssRules?.item(0) : null;\r\n let strMediaListItem = objCurrentCssRule.media?.length ? objCurrentCssRule?.media?.item(0) : null;\r\n if (objCSSStyleRule && strMediaListItem && objCSSStyleRule instanceof CSSStyleRule && mediaType.includes(strMediaListItem) && objCSSStyleRule?.selectorText === selectorText) {\r\n cssRule.deleteRule(k);\r\n objGroupClassNameInfo.objCss.delete(cssSelectors);\r\n offset = k;\r\n break;\r\n }\r\n }\r\n\r\n if (objCurrentCssRule instanceof CSSStyleRule && objCurrentCssRule?.selectorText === cssSelectors) {\r\n cssRule.deleteRule(k);\r\n objGroupClassNameInfo.objCss.delete(cssSelectors);\r\n offset = k;\r\n break;\r\n }\r\n\r\n if (objCurrentCssRule instanceof CSSKeyframesRule && cssSelectors.includes(\"@keyframes\") && objCurrentCssRule?.cssText?.includes(cssSelectors)) {\r\n const [keyframes, animateName] = cssSelectors.split(\" \");\r\n if (animateName && objCurrentCssRule?.name === animateName) {\r\n cssRule.deleteRule(k);\r\n objGroupClassNameInfo.objCss.delete(cssSelectors);\r\n offset = k;\r\n break;\r\n }\r\n }\r\n\r\n prevIdx = 0;\r\n offset = 0;\r\n from = 0;\r\n }\r\n }\r\n\r\n if (!objGroupClassNameInfo?.objCss?.size && !objGroupClassNameInfo?.usage?.size) {\r\n objCache.delete(mainCssClassName);\r\n }\r\n } catch (error) {\r\n if (pkgConfigStyle?.blnIsTestingMode) {\r\n console.warn(error);\r\n }\r\n }\r\n}\r\n","\"use client\";\n\nimport { getCacheStoreTrack, getCacheStyleSheetIndex } from \"../cache/MainCache\";\nimport { checkColorReturnValue } from \"./styleFunction\";\nimport * as styleVariables from \"./styleVariables\";\nimport { defaultApply, objCSSEntities, objCssHtmlJxsElement, objCssProperties, objCssPseudoClasses, objCssPseudoElements, objCssSymbols, objScreenSize } from \"./cssProperties\";\nimport getCssFormatValue from \"../defualtStyle/util/getCssFormatValue\";\nimport { cleanOne } from \"./cleanUp\";\nimport { pkgConfigStyle } from \"..\";\n\nconst semicolonReplacement = \"*-*\";\nconst keyframeSelectorReplacement = \"-|-\";\nconst splitMedia = \"-|-\";\nconst contentReplacement = \"~!\";\nconst cssRuleType = {\n CSSStyleRule: \"CSSStyleRule\",\n CSSMediaRule: \"CSSMediaRule\",\n CSSKeyframesRule: \"CSSKeyframesRule\",\n};\n\nasync function convertJsObjectToCss(orgClassName, idComp, newObjStyles, cacheTrackCssRule, styleSheetIdx, size = null) {\n const styleSheet = document?.styleSheets?.[styleSheetIdx];\n const cacheTrackPairs = cacheTrackCssRule.get(orgClassName);\n\n if (typeof newObjStyles !== \"object\") {\n return true;\n }\n\n const lstStyle = Object.entries(newObjStyles || {});\n if (!lstStyle?.length) {\n return true;\n }\n\n let blnIsInsertCorrectly = true;\n for (let i = 0; i < lstStyle.length; i++) {\n const cssRule = lstStyle[i];\n const subClassName = cssRule[0].trim();\n\n let cssTest = `${subClassName}${String(String(JSON.stringify(cssRule[1])).replaceAll('\"', \"\"))\n .replaceAll(\",\", \";\")\n .replaceAll(contentReplacement, `\"`)\n .replaceAll(keyframeSelectorReplacement + \":\", \" \")\n .replaceAll(\";\" + keyframeSelectorReplacement, \" \")\n .replaceAll(keyframeSelectorReplacement, \" \")\n .replaceAll(semicolonReplacement, \",\")}`;\n\n if (!size) {\n if (!cacheTrackPairs?.objCss) {\n blnIsInsertCorrectly = false;\n break;\n }\n if (cacheTrackPairs?.objCss?.has(subClassName)) {\n continue;\n }\n try {\n let intAfterAddIndex = styleSheet.insertRule(cssTest, styleSheet.cssRules.length);\n cacheTrackPairs.objCss.set(subClassName, { idx: intAfterAddIndex });\n } catch (error) {\n if (pkgConfigStyle?.blnIsTestingMode) {\n console.error(orgClassName, error);\n }\n }\n } else if (size) {\n if (!cacheTrackPairs?.objCss) {\n blnIsInsertCorrectly = false;\n break;\n }\n if (cacheTrackPairs?.objCss?.has(`${size}${splitMedia}${subClassName}`)) {\n continue;\n }\n try {\n let intAfterAddIndex = styleSheet.insertRule(\n `${size}{\n ${cssTest}\n }`,\n styleSheet.cssRules.length\n );\n cacheTrackPairs.objCss.set(`${size}${splitMedia}${subClassName}`, { idx: intAfterAddIndex });\n } catch (error) {\n if (pkgConfigStyle?.blnIsTestingMode) {\n console.error(orgClassName, error);\n }\n }\n }\n }\n\n return blnIsInsertCorrectly;\n}\n\nasync function setSheetRule(orgClassName, className, blnIsDefaultStyle, blnCbmisStyle, objStyles, appStyleConfig, idComp) {\n try {\n const newObjStyles = { ...objStyles };\n\n const xsScrSizeObj = objStyles?.[styleVariables.xsScrSize] || null;\n const smScrSizeObj = objStyles?.[styleVariables.smScrSize] || null;\n const mdScrSizeObj = objStyles?.[styleVariables.mdScrSize] || null;\n const lgScrSizeObj = objStyles?.[styleVariables.lgScrSize] || null;\n const xlScrSizeObj = objStyles?.[styleVariables.xlScrSize] || null;\n\n delete newObjStyles?.[styleVariables.xsScrSize];\n delete newObjStyles?.[styleVariables.smScrSize];\n delete newObjStyles?.[styleVariables.mdScrSize];\n delete newObjStyles?.[styleVariables.lgScrSize];\n delete newObjStyles?.[styleVariables.xlScrSize];\n\n const cacheTrackCssRule = getCacheStoreTrack(appStyleConfig, { blnCbmisStyle, blnIsDefaultStyle });\n const styleSheetIdx = getCacheStyleSheetIndex(appStyleConfig, { blnCbmisStyle, blnIsDefaultStyle });\n\n let blnIsInsertCorrectly = true;\n\n if (newObjStyles?.[className]) {\n blnIsInsertCorrectly &&= await convertJsObjectToCss(orgClassName, idComp, { [className]: newObjStyles?.[className] }, cacheTrackCssRule, styleSheetIdx);\n delete newObjStyles?.[className];\n }\n if (newObjStyles) {\n blnIsInsertCorrectly &&= await convertJsObjectToCss(orgClassName, idComp, newObjStyles, cacheTrackCssRule, styleSheetIdx);\n }\n\n const classPairs = { [className]: className };\n\n if (xlScrSizeObj) {\n if (xlScrSizeObj?.[className]) {\n classPairs[className] = xlScrSizeObj?.[className];\n blnIsInsertCorrectly &&= await convertJsObjectToCss(orgClassName, idComp, classPairs, cacheTrackCssRule, styleSheetIdx, styleVariables.xlScrSize);\n delete xlScrSizeObj?.[className];\n }\n if (xlScrSizeObj) {\n blnIsInsertCorrectly &&= await convertJsObjectToCss(orgClassName, idComp, xlScrSizeObj, cacheTrackCssRule, styleSheetIdx, styleVariables.xlScrSize);\n }\n }\n if (lgScrSizeObj) {\n if (lgScrSizeObj?.[className]) {\n classPairs[className] = lgScrSizeObj?.[className];\n blnIsInsertCorrectly &&= await convertJsObjectToCss(orgClassName, idComp, classPairs, cacheTrackCssRule, styleSheetIdx, styleVariables.lgScrSize);\n delete lgScrSizeObj?.[className];\n }\n if (lgScrSizeObj) {\n blnIsInsertCorrectly &&= await convertJsObjectToCss(orgClassName, idComp, lgScrSizeObj, cacheTrackCssRule, styleSheetIdx, styleVariables.lgScrSize);\n }\n }\n if (mdScrSizeObj) {\n if (mdScrSizeObj?.[className]) {\n classPairs[className] = mdScrSizeObj?.[className];\n blnIsInsertCorrectly &&= await convertJsObjectToCss(orgClassName, idComp, classPairs, cacheTrackCssRule, styleSheetIdx, styleVariables.mdScrSize);\n delete mdScrSizeObj?.[className];\n }\n if (mdScrSizeObj) {\n blnIsInsertCorrectly &&= await convertJsObjectToCss(orgClassName, idComp, mdScrSizeObj, cacheTrackCssRule, styleSheetIdx, styleVariables.mdScrSize);\n }\n }\n if (smScrSizeObj) {\n if (smScrSizeObj?.[className]) {\n classPairs[className] = smScrSizeObj?.[className];\n blnIsInsertCorrectly &&= await convertJsObjectToCss(orgClassName, idComp, classPairs, cacheTrackCssRule, styleSheetIdx, styleVariables.smScrSize);\n delete smScrSizeObj?.[className];\n }\n if (smScrSizeObj) {\n blnIsInsertCorrectly &&= await convertJsObjectToCss(orgClassName, idComp, smScrSizeObj, cacheTrackCssRule, styleSheetIdx, styleVariables.smScrSize);\n }\n }\n if (xsScrSizeObj) {\n if (xsScrSizeObj?.[className]) {\n classPairs[className] = xsScrSizeObj?.[className];\n blnIsInsertCorrectly &&= await convertJsObjectToCss(orgClassName, idComp, classPairs, cacheTrackCssRule, styleSheetIdx, styleVariables.xsScrSize);\n delete xsScrSizeObj?.[className];\n }\n if (xsScrSizeObj) {\n blnIsInsertCorrectly &&= await convertJsObjectToCss(orgClassName, idComp, xsScrSizeObj, cacheTrackCssRule, styleSheetIdx, styleVariables.xsScrSize);\n }\n }\n return blnIsInsertCorrectly;\n } catch (error) {\n if (pkgConfigStyle?.blnIsTestingMode) {\n console.error(error);\n }\n return false;\n }\n}\n\nasync function convertPropsFromJsToCss(_cssKey = \"\", _objInputStyle = {}, _objOutputResult = {}) {\n let objOutput = _objOutputResult;\n const objInputResult = {};\n\n if (typeof _objInputStyle !== \"object\") {\n return objOutput;\n }\n\n let lstSource = Object.entries(_objInputStyle || {});\n\n for (let i = 0; i < lstSource.length; i++) {\n const [key, value] = lstSource[i];\n\n if (objScreenSize?.[key]) {\n if (!objOutput?.[objScreenSize?.[key]]) {\n objOutput[objScreenSize?.[key]] = { [_cssKey]: value };\n }\n\n objOutput[objScreenSize?.[key]] = { ...objOutput?.[objScreenSize?.[key]], ...(await convertPropsFromJsToCss(_cssKey, value, {})) };\n } else if (typeof value !== \"object\" && objCssProperties?.[key]) {\n if (objCssProperties?.[key] === objCssProperties?.content) {\n lstSource[i][1] = contentReplacement + (objCSSEntities?.[value] ? objCSSEntities?.[value] : value) + contentReplacement;\n }\n\n if (String(objCssProperties?.[key]).toLowerCase().includes(objCssProperties?.color) || objCssProperties?.[key] === objCssProperties?.background || objCssProperties?.[key] === objCssProperties?.backgroundColor || objCssProperties?.[key] === objCssProperties?.borderColor) {\n lstSource[i][1] = checkColorReturnValue(value);\n }\n\n objInputResult[objCssProperties?.[key]] = String(lstSource[i][1]).replaceAll(\",\", semicolonReplacement);\n objOutput[_cssKey] = objInputResult;\n } else if (objCssPseudoClasses?.[key]) {\n objOutput = { ...objOutput, ...(await convertPropsFromJsToCss(`${_cssKey}:${objCssPseudoClasses?.[key]}`, value, {})) };\n } else if (objCssPseudoElements?.[key]) {\n objOutput = { ...objOutput, ...(await convertPropsFromJsToCss(`${_cssKey}::${objCssPseudoElements?.[key]}`, value, {})) };\n } else if (objCssHtmlJxsElement?.[key]) {\n objOutput = { ...objOutput, ...(await convertPropsFromJsToCss(`${_cssKey} ${objCssHtmlJxsElement?.[key]}`, value, {})) };\n } else if (objCssSymbols?.[key]) {\n objOutput = { ...objOutput, ...(await convertPropsFromJsToCss(`${_cssKey} ${objCssSymbols?.[key]}`, value, {})) };\n } else if (key?.[0] === \".\" || key?.[0] === \"#\" || key?.[0] === \",\" || key?.[0] === \"+\" || key?.[0] === \">\") {\n objOutput = { ...objOutput, ...(await convertPropsFromJsToCss(`${_cssKey} ${key}`, value, objOutput)) };\n } else if (String(key).toLowerCase().includes(\"@keyframes\")) {\n objOutput = { ...objOutput, ...(await convertPropsFromJsToCss(`${key}`, value, {})) };\n } else if (String(key).toLowerCase() === \"from\" || String(key).toLowerCase() === \"to\" || String(key).toLowerCase().includes(\"%\")) {\n objOutput[_cssKey] = { ...objOutput[_cssKey], ...(await convertPropsFromJsToCss(`${keyframeSelectorReplacement}${key}${keyframeSelectorReplacement}`, value, {})) };\n } else if (defaultApply?.[key]) {\n const lstDefaultClasses = Array.isArray(value) ? value : String(value)?.split(\" \");\n let outputDefault = {};\n for (let index = 0; index < lstDefaultClasses.length; index++) {\n const strDefClass = lstDefaultClasses?.[index];\n if (!strDefClass) {\n continue;\n }\n outputDefault = { ...outputDefault, ...getCssFormatValue(strDefClass) };\n }\n objOutput[_cssKey] = { ...objOutput[_cssKey], ...outputDefault };\n }\n }\n\n return objOutput;\n}\n\n//#region set sx style\nasync function setSxClassName(className, objStyle, blnIsDefaultStyle, blnCbmisStyle, appStyleConfig, idComp) {\n try {\n if (className) {\n let classNameTmp = String(className).includes(\"&[\") ? `${className.replace(\"&[\", \"[\")}` : `.${className}`;\n const objOutputResult = await convertPropsFromJsToCss(classNameTmp, objStyle, {});\n if (!Object.keys(objOutputResult)?.length) {\n return;\n }\n await setSheetRule(className, classNameTmp, blnIsDefaultStyle, blnCbmisStyle, objOutputResult, appStyleConfig, idComp);\n /* if (!result) {\n const cacheTrackCssRule = getCacheStoreTrack(appStyleConfig, { blnCbmisStyle, blnIsDefaultStyle });\n if (!cacheTrackCssRule?.has(className)) {\n cacheTrackCssRule.set(className, { usage: new Set(), objCss: new Map() });\n }\n const result1 = await setSheetRule(className, classNameTmp, blnIsDefaultStyle, blnCbmisStyle, objOutputResult, appStyleConfig, idComp);\n } */\n }\n } catch (error) {\n if (pkgConfigStyle?.blnIsTestingMode) {\n console.error(error);\n }\n }\n}\n\nexport async function setCssRules(_styleRef, _props, { idComp, lstStyleClasses, className, objStyles, sx, blnIsDefaultStyle, blnCbmisStyle, appStyleConfig }, patch = false) {\n try {\n if (!objStyles && !className && !sx) {\n return;\n }\n\n if (!patch) {\n if (_styleRef?.blnInsertRun) {\n return;\n }\n _styleRef.blnInsertRun = true;\n }\n\n if (patch) {\n if (_styleRef?.blnPatchRun) {\n return;\n }\n _styleRef.blnPatchRun = true;\n }\n\n for (let i = 0; i < lstStyleClasses.length; i++) {\n let strClassName_client = className ? className : lstStyleClasses?.[i]?.[0];\n let strClassName_rule = _styleRef?.objClassesNames?.[strClassName_client];\n\n if (!strClassName_client || !strClassName_rule) {\n continue;\n }\n\n if (!patch && _styleRef?.objDelMicro?.[strClassName_client]) {\n continue;\n }\n\n if (patch && !_styleRef?.objDelMicro?.[strClassName_client]) {\n continue;\n }\n\n const cacheTrackCssRule = getCacheStoreTrack(appStyleConfig, { blnCbmisStyle, blnIsDefaultStyle });\n\n if (patch && _styleRef?.objDelMicro?.[strClassName_client]) {\n if (pkgConfigStyle?.enableCleanChangedStyles) {\n await cleanOne(idComp, blnIsDefaultStyle, blnCbmisStyle, appStyleConfig, _styleRef?.objDelMicro?.[strClassName_client]?.strClassName_rule, strClassName_client);\n }\n delete _styleRef?.objDelMicro?.[strClassName_client];\n }\n\n let inlineStyle = lstStyleClasses?.[i]?.[1];\n if (typeof inlineStyle === \"function\") {\n inlineStyle = inlineStyle(_props);\n if (!inlineStyle) {\n continue;\n }\n }\n\n if (!cacheTrackCssRule?.has(strClassName_rule)) {\n cacheTrackCssRule.set(strClassName_rule, { usage: new Set(), objCss: new Map() });\n await setSxClassName(strClassName_rule, inlineStyle, blnIsDefaultStyle, blnCbmisStyle, appStyleConfig, idComp);\n } else if (!cacheTrackCssRule?.get(strClassName_rule)?.objCss?.size) {\n await setSxClassName(strClassName_rule, inlineStyle, blnIsDefaultStyle, blnCbmisStyle, appStyleConfig, idComp);\n }\n\n const currentGroupCss = cacheTrackCssRule?.get(strClassName_rule);\n\n if (idComp && currentGroupCss?.objCss?.size && !currentGroupCss?.usage?.has(idComp)) {\n currentGroupCss.usage.add(idComp);\n }\n\n if (!currentGroupCss?.objCss?.size) {\n cacheTrackCssRule.delete(strClassName_rule);\n }\n }\n\n if (!patch) {\n _styleRef.blnInsertRun = false;\n }\n if (patch) {\n _styleRef.blnPatchRun = false;\n }\n } catch (error) {\n if (pkgConfigStyle?.blnIsTestingMode) {\n console.error(error);\n }\n _styleRef.blnInsertRun = false;\n _styleRef.blnPatchRun = false;\n }\n}\n//#endregion\n","\"use client\";\r\n\r\nimport { useId, useInsertionEffect, useMemo, useRef } from \"react\";\r\nimport { setClassHash } from \"../helper/generateClassName\";\r\nimport { setCssRules } from \"../helper/convertJsCss\";\r\nimport { cleanRule } from \"../helper/cleanUp\";\r\nimport { pkgConfigStyle } from \"..\";\r\n\r\n/**\r\n * @typedef {{[x:string]: {[Property in keyof import(\"../../dist/types/cssProperties\").CBMISCSSProperties]?: any}}} jsCSS\r\n */\r\nexport const StyleBuilder = (appStyleConfig) =>\r\n /**\r\n * @template S\r\n * @param {{objStyles?: S | jsCSS, sx?: {[x: string] : any}, className?: string, blnRandomPrefix?: boolean, blnIsDefaultStyle?: boolean, blnCbmisStyle?: boolean }} styleBuilderProps\r\n */\r\n function StyleBuilder({ className = \"\", objStyles = null, sx = null, blnRandomPrefix = false, blnIsDefaultStyle = false, blnCbmisStyle = false }) {\r\n /**\r\n * @returns {S}\r\n */\r\n function useMakTheme(props) {\r\n const idComp = useId();\r\n const styleRef = useRef({ intVersion: 1, objDelMicro: {}, prevProps: null, objClassesNames: null, blnInitRun: false, blnInsertRun: false, blnPatchRun: false, lstStyleClasses: Object.entries((objStyles ? objStyles : className && sx ? { [className]: sx } : {}) || {}) });\r\n\r\n const styleObjectName = useMemo(() => {\r\n const prevVersion = styleRef?.current?.intVersion;\r\n const objClassNameHash = setClassHash(styleRef?.current, props, { blnRandomPrefix, lstStyleClasses: styleRef?.current?.lstStyleClasses, className, objStyles, sx });\r\n if (styleRef?.current?.intVersion !== prevVersion && styleRef?.current?.blnInitRun) {\r\n setCssRules(styleRef?.current, props, { idComp, lstStyleClasses: styleRef?.current?.lstStyleClasses, className, objStyles, sx, blnIsDefaultStyle, blnCbmisStyle, appStyleConfig }, true);\r\n }\r\n styleRef.current.blnInitRun = true;\r\n return objClassNameHash;\r\n }, [props]);\r\n\r\n useInsertionEffect(() => {\r\n if (typeof document !== \"undefined\" && typeof window !== \"undefined\") {\r\n setCssRules(styleRef?.current, props, { idComp, lstStyleClasses: styleRef?.current?.lstStyleClasses, className, objStyles, sx, blnIsDefaultStyle, blnCbmisStyle, appStyleConfig });\r\n }\r\n return () => {\r\n if (typeof document !== \"undefined\" && typeof window !== \"undefined\" && pkgConfigStyle?.enableCleanUpStyles) {\r\n cleanRule(idComp, blnIsDefaultStyle, blnCbmisStyle, appStyleConfig, styleRef?.current, props, styleRef?.current?.lstStyleClasses);\r\n }\r\n };\r\n }, []);\r\n\r\n return styleObjectName;\r\n }\r\n\r\n return useMakTheme;\r\n };\r\n","\"use client\";\r\nimport { StyleBuilder } from \"..\";\r\n\r\nexport default function ClassesBuilder(objStyles, props = {}, objOption) {\r\n const classesClient = StyleBuilder({\r\n blnRandomPrefix: typeof objOption?.blnRandomPrefix !== \"boolean\" ? true : objOption?.blnRandomPrefix,\r\n blnIsDefaultStyle: false,\r\n blnCbmisStyle: false,\r\n objStyles: { ...objStyles },\r\n });\r\n return classesClient(props);\r\n}\r\nexport function makeStyle(rules) {\r\n return rules;\r\n}\r\n","import React from \"react\";\r\n// import useTheme from './useTheme';\r\nimport { defaultBaseSize } from \"./cssVariables\";\r\nimport { mainTheme, objCss } from \"./cssVariables\";\r\n\r\nexport const ContextThemeProvider = React.createContext({});\r\n\r\nfunction ThemeProvider({ children, themes = null, currentTheme = null, baseSize = defaultBaseSize, currentBaseSize = defaultBaseSize }) {\r\n // const {theTheme}= useTheme({themes,currentTheme,baseSize})\r\n return (\r\n \r\n {children}\r\n \r\n );\r\n}\r\n\r\nexport default ThemeProvider;\r\n","// @ts-nocheck\r\n\r\n\"use client\";\r\n\r\nimport { baseSizeLG, baseSizeMD, baseSizeSM, baseSizeXL, baseSizeXS } from \"./cssVariables\";\r\n\r\nexport const localStorageName = \"app-themes-list-name\";\r\nexport const localStorageNameBaseSiz = \"app-themes-base-size\";\r\n\r\nexport const appDefaultThemes = [\"lightMode\", \"engMode\", \"sizeSM\"];\r\n\r\nexport default function ChangeThemes(listThemes = appDefaultThemes) {\r\n var appThemes = listThemes;\r\n // if(Array.isArray(listThemes?.lst)){\r\n // appThemes = JSON.stringify(listThemes?.lst)\r\n // }\r\n if (Array.isArray(listThemes)) {\r\n appThemes = JSON.stringify(listThemes);\r\n }\r\n // switch (String(appThemes?.[2]).slice(-2)) {\r\n // case \"xs\":\r\n // localStorage?.setItem(localStorageNameBaseSiz, baseSizeXS)\r\n // break;\r\n // case \"sm\":\r\n // localStorage?.setItem(localStorageNameBaseSiz, baseSizeSM)\r\n // break;\r\n // case \"lg\":\r\n // localStorage?.setItem(localStorageNameBaseSiz, baseSizeLG)\r\n // break;\r\n // case \"xl\":\r\n // localStorage?.setItem(localStorageNameBaseSiz, baseSizeXL)\r\n // break;\r\n // default:\r\n // localStorage?.setItem(localStorageNameBaseSiz, baseSizeMD)\r\n // break;\r\n // }\r\n // localStorage?.setItem(localStorageName, appThemes)\r\n}\r\n","import React, { useState, useEffect } from \"react\";\r\n\r\nfunction StyledComponentsRegistry(props) {\r\n const { LoadingComponent = null } = props;\r\n const [isLoading, setIsLoading] = useState(true);\r\n\r\n useEffect(() => {\r\n // Simulate an API call\r\n // setTimeout(() => {\r\n setIsLoading(false);\r\n // }, 5);\r\n }, []);\r\n\r\n if (isLoading) {\r\n return LoadingComponent ? : null;\r\n }\r\n return props.children;\r\n}\r\n\r\nexport default StyledComponentsRegistry;\r\n","function buildSymmetricalValueObject(lstTargetCssProperties, _objInputStyle = {}, replaceFunction, _objOutputResult = {}) {\r\n let objOutput = _objOutputResult;\r\n\r\n if (typeof _objInputStyle !== \"object\") {\r\n return objOutput;\r\n }\r\n\r\n let lstSource = Object.entries(_objInputStyle || {});\r\n\r\n for (let i = 0; i < lstSource.length; i++) {\r\n const [key, value] = lstSource[i];\r\n\r\n if (typeof value !== \"object\" && lstTargetCssProperties?.includes(key)) {\r\n if (replaceFunction && typeof replaceFunction === \"function\") {\r\n objOutput = { ...objOutput, ...(replaceFunction(key, value) || {}) };\r\n } else {\r\n objOutput[key] = value;\r\n }\r\n } else if (typeof value === \"object\") {\r\n let result = buildSymmetricalValueObject(lstTargetCssProperties, value, replaceFunction);\r\n if (typeof result === \"object\" && Object.keys(result)?.length) {\r\n objOutput[key] = result;\r\n }\r\n }\r\n }\r\n\r\n return objOutput;\r\n}\r\n\r\nexport const getSpecificCssRule = (lstTargetCssRules, objInputStyle, replaceFunction) => {\r\n const result = buildSymmetricalValueObject(lstTargetCssRules, objInputStyle, replaceFunction);\r\n return result;\r\n};\r\n\r\nexport const sizeValuesSetter = (objInputStyle, setterFunction) => {\r\n const sizeSequence = [\"default\", \"xs\", \"sm\", \"md\", \"lg\", \"xl\"];\r\n let objResult = {};\r\n\r\n for (let i = 0; i < sizeSequence.length; i++) {\r\n let resultDefault = {};\r\n if (sizeSequence[i] === \"default\") {\r\n resultDefault = setterFunction(sizeSequence[i]);\r\n if (resultDefault && typeof resultDefault === \"object\" && Object.keys(resultDefault || {}).length) {\r\n objResult = { ...objResult, ...resultDefault };\r\n }\r\n } else {\r\n if (objInputStyle?.[sizeSequence[i]]) {\r\n let customSize = setterFunction(sizeSequence[i], objInputStyle?.[sizeSequence[i]]);\r\n if (customSize && typeof customSize === \"object\" && Object.keys(customSize || {}).length) {\r\n objResult = { ...objResult, ...customSize, [sizeSequence[i]]: customSize };\r\n }\r\n }\r\n }\r\n }\r\n\r\n return objResult;\r\n};\r\n\r\nexport const sizeOneValueSetter = (cssProp, objInputStyle) => {\r\n let objResult = {};\r\n if (typeof objInputStyle === \"string\" || typeof objInputStyle === \"number\") {\r\n objResult[cssProp] = objInputStyle;\r\n } else if (typeof objInputStyle === \"object\") {\r\n const sizeSequence = [\"xs\", \"sm\", \"md\", \"lg\", \"xl\"];\r\n for (let i = 0; i < sizeSequence.length; i++) {\r\n if (objInputStyle?.[sizeSequence[i]] && (typeof objInputStyle?.[sizeSequence[i]] === \"string\" || typeof objInputStyle?.[sizeSequence[i]] === \"number\")) {\r\n let customSize = { [cssProp]: objInputStyle?.[sizeSequence[i]] };\r\n objResult = { ...objResult, ...customSize, [sizeSequence[i]]: customSize };\r\n }\r\n }\r\n }\r\n return objResult;\r\n};\r\n\r\nexport const sizeValuesSelectDefault = (objInputStyle) => {\r\n const sizeSequence = [\"xs\", \"sm\", \"md\", \"lg\", \"xl\"];\r\n let defaultValue = \"initial\";\r\n\r\n for (let i = 0; i < sizeSequence.length; i++) {\r\n if (objInputStyle?.[sizeSequence[i]]) {\r\n defaultValue = objInputStyle?.[sizeSequence[i]];\r\n }\r\n }\r\n\r\n return defaultValue;\r\n};\r\n\r\nexport const aggregationSizeStyle = (...lstSizeStyle) => {\r\n let objResult = {};\r\n if (lstSizeStyle?.length) {\r\n for (let index = 0; index < lstSizeStyle.length; index++) {\r\n const objInputStyle = lstSizeStyle[index];\r\n if (objInputStyle?.xs) {\r\n objResult.xs = {\r\n ...objResult.xs,\r\n ...(objInputStyle?.xs || {}),\r\n };\r\n delete objInputStyle?.xs;\r\n }\r\n if (objInputStyle?.sm) {\r\n objResult.sm = {\r\n ...objResult.sm,\r\n ...(objInputStyle?.sm || {}),\r\n };\r\n delete objInputStyle?.sm;\r\n }\r\n if (objInputStyle?.md) {\r\n objResult.md = {\r\n ...objResult.md,\r\n ...(objInputStyle?.md || {}),\r\n };\r\n delete objInputStyle?.md;\r\n }\r\n if (objInputStyle?.lg) {\r\n objResult.lg = {\r\n ...objResult.lg,\r\n ...(objInputStyle?.lg || {}),\r\n };\r\n delete objInputStyle?.lg;\r\n }\r\n if (objInputStyle?.xl) {\r\n objResult.xl = {\r\n ...objResult.xl,\r\n ...(objInputStyle?.xl || {}),\r\n };\r\n delete objInputStyle?.xl;\r\n }\r\n\r\n objResult = { ...objResult, ...(objInputStyle || {}) };\r\n }\r\n }\r\n return objResult;\r\n};\r\n\r\n// const result = sizeValuesSetter({ xs: \"center\", sm: \"end\", md: \"start\", lg: \"flex-between\" }, (size, styleValue) => {\r\n// return {\r\n// xl: { justifyContent: styleValue },\r\n// lg: { justifyContent: styleValue },\r\n// md: { justifyContent: styleValue },\r\n// sm: { justifyContent: styleValue },\r\n// xs: { justifyContent: styleValue },\r\n// default: { justifyContent: \"flex-start\" },\r\n// }?.[size];\r\n// });\r\n\r\n// const result1 = sizeValuesSelectDefault({ xs: \"center\", sm: \"end\", md: \"start\", lg: \"flex-between\" });\r\n","\"use client\";\r\n\r\nfunction getPkgConfigStyle() {\r\n const initConfig = {\r\n blnIsTestingMode: true,\r\n enableCleanUpStyles: true,\r\n enableCleanChangedStyles: true,\r\n };\r\n return initConfig;\r\n}\r\n\r\nexport var pkgConfigStyle = getPkgConfigStyle();\r\n\r\nexport function setPkgConfigStyle(config) {\r\n let newConfig = config;\r\n if (!newConfig) {\r\n newConfig = {};\r\n }\r\n if (typeof newConfig?.blnIsTestingMode !== \"boolean\") {\r\n newConfig.blnIsTestingMode = true;\r\n }\r\n if (typeof newConfig?.enableCleanUpStyles !== \"boolean\") {\r\n newConfig.enableCleanUpStyles = true;\r\n }\r\n if (typeof newConfig?.enableCleanChangedStyles !== \"boolean\") {\r\n newConfig.enableCleanChangedStyles = true;\r\n }\r\n pkgConfigStyle.blnIsTestingMode = newConfig.blnIsTestingMode;\r\n pkgConfigStyle.enableCleanUpStyles = newConfig.enableCleanUpStyles;\r\n pkgConfigStyle.enableCleanChangedStyles = newConfig.enableCleanChangedStyles;\r\n}\r\n\r\nimport \"./style/main.css\";\r\nimport \"./style/themes.css\";\r\nimport \"./style/dataCbmisDefault.css\";\r\nimport \"./style/dataCbmisSx.css\";\r\nimport \"./style/dataClientStyle.css\";\r\n\r\nimport MainCache from \"./cache/MainCache\";\r\nconst cache = MainCache();\r\n\r\nimport { StyleBuilder as StyleBuilderFun } from \"./styleBuilder/StyleBuilder\";\r\n\r\nexport const StyleBuilder = StyleBuilderFun(cache);\r\n\r\nexport { default as ClassesBuilder, makeStyle } from \"./styleBuilder/ClassesBuilder\";\r\n\r\nexport { default as ThemeProvider } from \"./themeProvider/ThemeProvider\";\r\n\r\nexport { default as ChangeThemes } from \"./themeProvider/ChangeThemes\";\r\n\r\nexport { default as StyledComponentsRegistry } from \"./styledComponentsRegistry/StyledComponentsRegistry\";\r\n\r\nexport * as styleFunction from \"./helper/styleFunction\";\r\nexport * as styleVariables from \"./helper/styleVariables\";\r\nexport { getSpecificCssRule, sizeValuesSetter, sizeValuesSelectDefault , sizeOneValueSetter, aggregationSizeStyle} from \"./helper/cssRulesUtils\";\r\n\r\nexport { objCss, cssKeys, globalValues, mainTheme } from \"./themeProvider/cssVariables\";\r\n\r\nexport { ContextThemeProvider } from \"./themeProvider/ThemeProvider\";\r\n",";(function (root, factory, undef) {\n\tif (typeof exports === \"object\") {\n\t\t// CommonJS\n\t\tmodule.exports = exports = factory(require(\"./core\"), require(\"./enc-base64\"), require(\"./md5\"), require(\"./evpkdf\"), require(\"./cipher-core\"));\n\t}\n\telse if (typeof define === \"function\" && define.amd) {\n\t\t// AMD\n\t\tdefine([\"./core\", \"./enc-base64\", \"./md5\", \"./evpkdf\", \"./cipher-core\"], factory);\n\t}\n\telse {\n\t\t// Global (browser)\n\t\tfactory(root.CryptoJS);\n\t}\n}(this, function (CryptoJS) {\n\n\t(function () {\n\t // Shortcuts\n\t var C = CryptoJS;\n\t var C_lib = C.lib;\n\t var BlockCipher = C_lib.BlockCipher;\n\t var C_algo = C.algo;\n\n\t // Lookup tables\n\t var SBOX = [];\n\t var INV_SBOX = [];\n\t var SUB_MIX_0 = [];\n\t var SUB_MIX_1 = [];\n\t var SUB_MIX_2 = [];\n\t var SUB_MIX_3 = [];\n\t var INV_SUB_MIX_0 = [];\n\t var INV_SUB_MIX_1 = [];\n\t var INV_SUB_MIX_2 = [];\n\t var INV_SUB_MIX_3 = [];\n\n\t // Compute lookup tables\n\t (function () {\n\t // Compute double table\n\t var d = [];\n\t for (var i = 0; i < 256; i++) {\n\t if (i < 128) {\n\t d[i] = i << 1;\n\t } else {\n\t d[i] = (i << 1) ^ 0x11b;\n\t }\n\t }\n\n\t // Walk GF(2^8)\n\t var x = 0;\n\t var xi = 0;\n\t for (var i = 0; i < 256; i++) {\n\t // Compute sbox\n\t var sx = xi ^ (xi << 1) ^ (xi << 2) ^ (xi << 3) ^ (xi << 4);\n\t sx = (sx >>> 8) ^ (sx & 0xff) ^ 0x63;\n\t SBOX[x] = sx;\n\t INV_SBOX[sx] = x;\n\n\t // Compute multiplication\n\t var x2 = d[x];\n\t var x4 = d[x2];\n\t var x8 = d[x4];\n\n\t // Compute sub bytes, mix columns tables\n\t var t = (d[sx] * 0x101) ^ (sx * 0x1010100);\n\t SUB_MIX_0[x] = (t << 24) | (t >>> 8);\n\t SUB_MIX_1[x] = (t << 16) | (t >>> 16);\n\t SUB_MIX_2[x] = (t << 8) | (t >>> 24);\n\t SUB_MIX_3[x] = t;\n\n\t // Compute inv sub bytes, inv mix columns tables\n\t var t = (x8 * 0x1010101) ^ (x4 * 0x10001) ^ (x2 * 0x101) ^ (x * 0x1010100);\n\t INV_SUB_MIX_0[sx] = (t << 24) | (t >>> 8);\n\t INV_SUB_MIX_1[sx] = (t << 16) | (t >>> 16);\n\t INV_SUB_MIX_2[sx] = (t << 8) | (t >>> 24);\n\t INV_SUB_MIX_3[sx] = t;\n\n\t // Compute next counter\n\t if (!x) {\n\t x = xi = 1;\n\t } else {\n\t x = x2 ^ d[d[d[x8 ^ x2]]];\n\t xi ^= d[d[xi]];\n\t }\n\t }\n\t }());\n\n\t // Precomputed Rcon lookup\n\t var RCON = [0x00, 0x01, 0x02, 0x04, 0x08, 0x10, 0x20, 0x40, 0x80, 0x1b, 0x36];\n\n\t /**\n\t * AES block cipher algorithm.\n\t */\n\t var AES = C_algo.AES = BlockCipher.extend({\n\t _doReset: function () {\n\t var t;\n\n\t // Skip reset of nRounds has been set before and key did not change\n\t if (this._nRounds && this._keyPriorReset === this._key) {\n\t return;\n\t }\n\n\t // Shortcuts\n\t var key = this._keyPriorReset = this._key;\n\t var keyWords = key.words;\n\t var keySize = key.sigBytes / 4;\n\n\t // Compute number of rounds\n\t var nRounds = this._nRounds = keySize + 6;\n\n\t // Compute number of key schedule rows\n\t var ksRows = (nRounds + 1) * 4;\n\n\t // Compute key schedule\n\t var keySchedule = this._keySchedule = [];\n\t for (var ksRow = 0; ksRow < ksRows; ksRow++) {\n\t if (ksRow < keySize) {\n\t keySchedule[ksRow] = keyWords[ksRow];\n\t } else {\n\t t = keySchedule[ksRow - 1];\n\n\t if (!(ksRow % keySize)) {\n\t // Rot word\n\t t = (t << 8) | (t >>> 24);\n\n\t // Sub word\n\t t = (SBOX[t >>> 24] << 24) | (SBOX[(t >>> 16) & 0xff] << 16) | (SBOX[(t >>> 8) & 0xff] << 8) | SBOX[t & 0xff];\n\n\t // Mix Rcon\n\t t ^= RCON[(ksRow / keySize) | 0] << 24;\n\t } else if (keySize > 6 && ksRow % keySize == 4) {\n\t // Sub word\n\t t = (SBOX[t >>> 24] << 24) | (SBOX[(t >>> 16) & 0xff] << 16) | (SBOX[(t >>> 8) & 0xff] << 8) | SBOX[t & 0xff];\n\t }\n\n\t keySchedule[ksRow] = keySchedule[ksRow - keySize] ^ t;\n\t }\n\t }\n\n\t // Compute inv key schedule\n\t var invKeySchedule = this._invKeySchedule = [];\n\t for (var invKsRow = 0; invKsRow < ksRows; invKsRow++) {\n\t var ksRow = ksRows - invKsRow;\n\n\t if (invKsRow % 4) {\n\t var t = keySchedule[ksRow];\n\t } else {\n\t var t = keySchedule[ksRow - 4];\n\t }\n\n\t if (invKsRow < 4 || ksRow <= 4) {\n\t invKeySchedule[invKsRow] = t;\n\t } else {\n\t invKeySchedule[invKsRow] = INV_SUB_MIX_0[SBOX[t >>> 24]] ^ INV_SUB_MIX_1[SBOX[(t >>> 16) & 0xff]] ^\n\t INV_SUB_MIX_2[SBOX[(t >>> 8) & 0xff]] ^ INV_SUB_MIX_3[SBOX[t & 0xff]];\n\t }\n\t }\n\t },\n\n\t encryptBlock: function (M, offset) {\n\t this._doCryptBlock(M, offset, this._keySchedule, SUB_MIX_0, SUB_MIX_1, SUB_MIX_2, SUB_MIX_3, SBOX);\n\t },\n\n\t decryptBlock: function (M, offset) {\n\t // Swap 2nd and 4th rows\n\t var t = M[offset + 1];\n\t M[offset + 1] = M[offset + 3];\n\t M[offset + 3] = t;\n\n\t this._doCryptBlock(M, offset, this._invKeySchedule, INV_SUB_MIX_0, INV_SUB_MIX_1, INV_SUB_MIX_2, INV_SUB_MIX_3, INV_SBOX);\n\n\t // Inv swap 2nd and 4th rows\n\t var t = M[offset + 1];\n\t M[offset + 1] = M[offset + 3];\n\t M[offset + 3] = t;\n\t },\n\n\t _doCryptBlock: function (M, offset, keySchedule, SUB_MIX_0, SUB_MIX_1, SUB_MIX_2, SUB_MIX_3, SBOX) {\n\t // Shortcut\n\t var nRounds = this._nRounds;\n\n\t // Get input, add round key\n\t var s0 = M[offset] ^ keySchedule[0];\n\t var s1 = M[offset + 1] ^ keySchedule[1];\n\t var s2 = M[offset + 2] ^ keySchedule[2];\n\t var s3 = M[offset + 3] ^ keySchedule[3];\n\n\t // Key schedule row counter\n\t var ksRow = 4;\n\n\t // Rounds\n\t for (var round = 1; round < nRounds; round++) {\n\t // Shift rows, sub bytes, mix columns, add round key\n\t var t0 = SUB_MIX_0[s0 >>> 24] ^ SUB_MIX_1[(s1 >>> 16) & 0xff] ^ SUB_MIX_2[(s2 >>> 8) & 0xff] ^ SUB_MIX_3[s3 & 0xff] ^ keySchedule[ksRow++];\n\t var t1 = SUB_MIX_0[s1 >>> 24] ^ SUB_MIX_1[(s2 >>> 16) & 0xff] ^ SUB_MIX_2[(s3 >>> 8) & 0xff] ^ SUB_MIX_3[s0 & 0xff] ^ keySchedule[ksRow++];\n\t var t2 = SUB_MIX_0[s2 >>> 24] ^ SUB_MIX_1[(s3 >>> 16) & 0xff] ^ SUB_MIX_2[(s0 >>> 8) & 0xff] ^ SUB_MIX_3[s1 & 0xff] ^ keySchedule[ksRow++];\n\t var t3 = SUB_MIX_0[s3 >>> 24] ^ SUB_MIX_1[(s0 >>> 16) & 0xff] ^ SUB_MIX_2[(s1 >>> 8) & 0xff] ^ SUB_MIX_3[s2 & 0xff] ^ keySchedule[ksRow++];\n\n\t // Update state\n\t s0 = t0;\n\t s1 = t1;\n\t s2 = t2;\n\t s3 = t3;\n\t }\n\n\t // Shift rows, sub bytes, add round key\n\t var t0 = ((SBOX[s0 >>> 24] << 24) | (SBOX[(s1 >>> 16) & 0xff] << 16) | (SBOX[(s2 >>> 8) & 0xff] << 8) | SBOX[s3 & 0xff]) ^ keySchedule[ksRow++];\n\t var t1 = ((SBOX[s1 >>> 24] << 24) | (SBOX[(s2 >>> 16) & 0xff] << 16) | (SBOX[(s3 >>> 8) & 0xff] << 8) | SBOX[s0 & 0xff]) ^ keySchedule[ksRow++];\n\t var t2 = ((SBOX[s2 >>> 24] << 24) | (SBOX[(s3 >>> 16) & 0xff] << 16) | (SBOX[(s0 >>> 8) & 0xff] << 8) | SBOX[s1 & 0xff]) ^ keySchedule[ksRow++];\n\t var t3 = ((SBOX[s3 >>> 24] << 24) | (SBOX[(s0 >>> 16) & 0xff] << 16) | (SBOX[(s1 >>> 8) & 0xff] << 8) | SBOX[s2 & 0xff]) ^ keySchedule[ksRow++];\n\n\t // Set output\n\t M[offset] = t0;\n\t M[offset + 1] = t1;\n\t M[offset + 2] = t2;\n\t M[offset + 3] = t3;\n\t },\n\n\t keySize: 256/32\n\t });\n\n\t /**\n\t * Shortcut functions to the cipher's object interface.\n\t *\n\t * @example\n\t *\n\t * var ciphertext = CryptoJS.AES.encrypt(message, key, cfg);\n\t * var plaintext = CryptoJS.AES.decrypt(ciphertext, key, cfg);\n\t */\n\t C.AES = BlockCipher._createHelper(AES);\n\t}());\n\n\n\treturn CryptoJS.AES;\n\n}));",";(function (root, factory, undef) {\n\tif (typeof exports === \"object\") {\n\t\t// CommonJS\n\t\tmodule.exports = exports = factory(require(\"./core\"), require(\"./enc-base64\"), require(\"./md5\"), require(\"./evpkdf\"), require(\"./cipher-core\"));\n\t}\n\telse if (typeof define === \"function\" && define.amd) {\n\t\t// AMD\n\t\tdefine([\"./core\", \"./enc-base64\", \"./md5\", \"./evpkdf\", \"./cipher-core\"], factory);\n\t}\n\telse {\n\t\t// Global (browser)\n\t\tfactory(root.CryptoJS);\n\t}\n}(this, function (CryptoJS) {\n\n\t(function () {\n\t // Shortcuts\n\t var C = CryptoJS;\n\t var C_lib = C.lib;\n\t var BlockCipher = C_lib.BlockCipher;\n\t var C_algo = C.algo;\n\n\t const N = 16;\n\n\t //Origin pbox and sbox, derived from PI\n\t const ORIG_P = [\n\t 0x243F6A88, 0x85A308D3, 0x13198A2E, 0x03707344,\n\t 0xA4093822, 0x299F31D0, 0x082EFA98, 0xEC4E6C89,\n\t 0x452821E6, 0x38D01377, 0xBE5466CF, 0x34E90C6C,\n\t 0xC0AC29B7, 0xC97C50DD, 0x3F84D5B5, 0xB5470917,\n\t 0x9216D5D9, 0x8979FB1B\n\t ];\n\n\t const ORIG_S = [\n\t [ 0xD1310BA6, 0x98DFB5AC, 0x2FFD72DB, 0xD01ADFB7,\n\t 0xB8E1AFED, 0x6A267E96, 0xBA7C9045, 0xF12C7F99,\n\t 0x24A19947, 0xB3916CF7, 0x0801F2E2, 0x858EFC16,\n\t 0x636920D8, 0x71574E69, 0xA458FEA3, 0xF4933D7E,\n\t 0x0D95748F, 0x728EB658, 0x718BCD58, 0x82154AEE,\n\t 0x7B54A41D, 0xC25A59B5, 0x9C30D539, 0x2AF26013,\n\t 0xC5D1B023, 0x286085F0, 0xCA417918, 0xB8DB38EF,\n\t 0x8E79DCB0, 0x603A180E, 0x6C9E0E8B, 0xB01E8A3E,\n\t 0xD71577C1, 0xBD314B27, 0x78AF2FDA, 0x55605C60,\n\t 0xE65525F3, 0xAA55AB94, 0x57489862, 0x63E81440,\n\t 0x55CA396A, 0x2AAB10B6, 0xB4CC5C34, 0x1141E8CE,\n\t 0xA15486AF, 0x7C72E993, 0xB3EE1411, 0x636FBC2A,\n\t 0x2BA9C55D, 0x741831F6, 0xCE5C3E16, 0x9B87931E,\n\t 0xAFD6BA33, 0x6C24CF5C, 0x7A325381, 0x28958677,\n\t 0x3B8F4898, 0x6B4BB9AF, 0xC4BFE81B, 0x66282193,\n\t 0x61D809CC, 0xFB21A991, 0x487CAC60, 0x5DEC8032,\n\t 0xEF845D5D, 0xE98575B1, 0xDC262302, 0xEB651B88,\n\t 0x23893E81, 0xD396ACC5, 0x0F6D6FF3, 0x83F44239,\n\t 0x2E0B4482, 0xA4842004, 0x69C8F04A, 0x9E1F9B5E,\n\t 0x21C66842, 0xF6E96C9A, 0x670C9C61, 0xABD388F0,\n\t 0x6A51A0D2, 0xD8542F68, 0x960FA728, 0xAB5133A3,\n\t 0x6EEF0B6C, 0x137A3BE4, 0xBA3BF050, 0x7EFB2A98,\n\t 0xA1F1651D, 0x39AF0176, 0x66CA593E, 0x82430E88,\n\t 0x8CEE8619, 0x456F9FB4, 0x7D84A5C3, 0x3B8B5EBE,\n\t 0xE06F75D8, 0x85C12073, 0x401A449F, 0x56C16AA6,\n\t 0x4ED3AA62, 0x363F7706, 0x1BFEDF72, 0x429B023D,\n\t 0x37D0D724, 0xD00A1248, 0xDB0FEAD3, 0x49F1C09B,\n\t 0x075372C9, 0x80991B7B, 0x25D479D8, 0xF6E8DEF7,\n\t 0xE3FE501A, 0xB6794C3B, 0x976CE0BD, 0x04C006BA,\n\t 0xC1A94FB6, 0x409F60C4, 0x5E5C9EC2, 0x196A2463,\n\t 0x68FB6FAF, 0x3E6C53B5, 0x1339B2EB, 0x3B52EC6F,\n\t 0x6DFC511F, 0x9B30952C, 0xCC814544, 0xAF5EBD09,\n\t 0xBEE3D004, 0xDE334AFD, 0x660F2807, 0x192E4BB3,\n\t 0xC0CBA857, 0x45C8740F, 0xD20B5F39, 0xB9D3FBDB,\n\t 0x5579C0BD, 0x1A60320A, 0xD6A100C6, 0x402C7279,\n\t 0x679F25FE, 0xFB1FA3CC, 0x8EA5E9F8, 0xDB3222F8,\n\t 0x3C7516DF, 0xFD616B15, 0x2F501EC8, 0xAD0552AB,\n\t 0x323DB5FA, 0xFD238760, 0x53317B48, 0x3E00DF82,\n\t 0x9E5C57BB, 0xCA6F8CA0, 0x1A87562E, 0xDF1769DB,\n\t 0xD542A8F6, 0x287EFFC3, 0xAC6732C6, 0x8C4F5573,\n\t 0x695B27B0, 0xBBCA58C8, 0xE1FFA35D, 0xB8F011A0,\n\t 0x10FA3D98, 0xFD2183B8, 0x4AFCB56C, 0x2DD1D35B,\n\t 0x9A53E479, 0xB6F84565, 0xD28E49BC, 0x4BFB9790,\n\t 0xE1DDF2DA, 0xA4CB7E33, 0x62FB1341, 0xCEE4C6E8,\n\t 0xEF20CADA, 0x36774C01, 0xD07E9EFE, 0x2BF11FB4,\n\t 0x95DBDA4D, 0xAE909198, 0xEAAD8E71, 0x6B93D5A0,\n\t 0xD08ED1D0, 0xAFC725E0, 0x8E3C5B2F, 0x8E7594B7,\n\t 0x8FF6E2FB, 0xF2122B64, 0x8888B812, 0x900DF01C,\n\t 0x4FAD5EA0, 0x688FC31C, 0xD1CFF191, 0xB3A8C1AD,\n\t 0x2F2F2218, 0xBE0E1777, 0xEA752DFE, 0x8B021FA1,\n\t 0xE5A0CC0F, 0xB56F74E8, 0x18ACF3D6, 0xCE89E299,\n\t 0xB4A84FE0, 0xFD13E0B7, 0x7CC43B81, 0xD2ADA8D9,\n\t 0x165FA266, 0x80957705, 0x93CC7314, 0x211A1477,\n\t 0xE6AD2065, 0x77B5FA86, 0xC75442F5, 0xFB9D35CF,\n\t 0xEBCDAF0C, 0x7B3E89A0, 0xD6411BD3, 0xAE1E7E49,\n\t 0x00250E2D, 0x2071B35E, 0x226800BB, 0x57B8E0AF,\n\t 0x2464369B, 0xF009B91E, 0x5563911D, 0x59DFA6AA,\n\t 0x78C14389, 0xD95A537F, 0x207D5BA2, 0x02E5B9C5,\n\t 0x83260376, 0x6295CFA9, 0x11C81968, 0x4E734A41,\n\t 0xB3472DCA, 0x7B14A94A, 0x1B510052, 0x9A532915,\n\t 0xD60F573F, 0xBC9BC6E4, 0x2B60A476, 0x81E67400,\n\t 0x08BA6FB5, 0x571BE91F, 0xF296EC6B, 0x2A0DD915,\n\t 0xB6636521, 0xE7B9F9B6, 0xFF34052E, 0xC5855664,\n\t 0x53B02D5D, 0xA99F8FA1, 0x08BA4799, 0x6E85076A ],\n\t [ 0x4B7A70E9, 0xB5B32944, 0xDB75092E, 0xC4192623,\n\t 0xAD6EA6B0, 0x49A7DF7D, 0x9CEE60B8, 0x8FEDB266,\n\t 0xECAA8C71, 0x699A17FF, 0x5664526C, 0xC2B19EE1,\n\t 0x193602A5, 0x75094C29, 0xA0591340, 0xE4183A3E,\n\t 0x3F54989A, 0x5B429D65, 0x6B8FE4D6, 0x99F73FD6,\n\t 0xA1D29C07, 0xEFE830F5, 0x4D2D38E6, 0xF0255DC1,\n\t 0x4CDD2086, 0x8470EB26, 0x6382E9C6, 0x021ECC5E,\n\t 0x09686B3F, 0x3EBAEFC9, 0x3C971814, 0x6B6A70A1,\n\t 0x687F3584, 0x52A0E286, 0xB79C5305, 0xAA500737,\n\t 0x3E07841C, 0x7FDEAE5C, 0x8E7D44EC, 0x5716F2B8,\n\t 0xB03ADA37, 0xF0500C0D, 0xF01C1F04, 0x0200B3FF,\n\t 0xAE0CF51A, 0x3CB574B2, 0x25837A58, 0xDC0921BD,\n\t 0xD19113F9, 0x7CA92FF6, 0x94324773, 0x22F54701,\n\t 0x3AE5E581, 0x37C2DADC, 0xC8B57634, 0x9AF3DDA7,\n\t 0xA9446146, 0x0FD0030E, 0xECC8C73E, 0xA4751E41,\n\t 0xE238CD99, 0x3BEA0E2F, 0x3280BBA1, 0x183EB331,\n\t 0x4E548B38, 0x4F6DB908, 0x6F420D03, 0xF60A04BF,\n\t 0x2CB81290, 0x24977C79, 0x5679B072, 0xBCAF89AF,\n\t 0xDE9A771F, 0xD9930810, 0xB38BAE12, 0xDCCF3F2E,\n\t 0x5512721F, 0x2E6B7124, 0x501ADDE6, 0x9F84CD87,\n\t 0x7A584718, 0x7408DA17, 0xBC9F9ABC, 0xE94B7D8C,\n\t 0xEC7AEC3A, 0xDB851DFA, 0x63094366, 0xC464C3D2,\n\t 0xEF1C1847, 0x3215D908, 0xDD433B37, 0x24C2BA16,\n\t 0x12A14D43, 0x2A65C451, 0x50940002, 0x133AE4DD,\n\t 0x71DFF89E, 0x10314E55, 0x81AC77D6, 0x5F11199B,\n\t 0x043556F1, 0xD7A3C76B, 0x3C11183B, 0x5924A509,\n\t 0xF28FE6ED, 0x97F1FBFA, 0x9EBABF2C, 0x1E153C6E,\n\t 0x86E34570, 0xEAE96FB1, 0x860E5E0A, 0x5A3E2AB3,\n\t 0x771FE71C, 0x4E3D06FA, 0x2965DCB9, 0x99E71D0F,\n\t 0x803E89D6, 0x5266C825, 0x2E4CC978, 0x9C10B36A,\n\t 0xC6150EBA, 0x94E2EA78, 0xA5FC3C53, 0x1E0A2DF4,\n\t 0xF2F74EA7, 0x361D2B3D, 0x1939260F, 0x19C27960,\n\t 0x5223A708, 0xF71312B6, 0xEBADFE6E, 0xEAC31F66,\n\t 0xE3BC4595, 0xA67BC883, 0xB17F37D1, 0x018CFF28,\n\t 0xC332DDEF, 0xBE6C5AA5, 0x65582185, 0x68AB9802,\n\t 0xEECEA50F, 0xDB2F953B, 0x2AEF7DAD, 0x5B6E2F84,\n\t 0x1521B628, 0x29076170, 0xECDD4775, 0x619F1510,\n\t 0x13CCA830, 0xEB61BD96, 0x0334FE1E, 0xAA0363CF,\n\t 0xB5735C90, 0x4C70A239, 0xD59E9E0B, 0xCBAADE14,\n\t 0xEECC86BC, 0x60622CA7, 0x9CAB5CAB, 0xB2F3846E,\n\t 0x648B1EAF, 0x19BDF0CA, 0xA02369B9, 0x655ABB50,\n\t 0x40685A32, 0x3C2AB4B3, 0x319EE9D5, 0xC021B8F7,\n\t 0x9B540B19, 0x875FA099, 0x95F7997E, 0x623D7DA8,\n\t 0xF837889A, 0x97E32D77, 0x11ED935F, 0x16681281,\n\t 0x0E358829, 0xC7E61FD6, 0x96DEDFA1, 0x7858BA99,\n\t 0x57F584A5, 0x1B227263, 0x9B83C3FF, 0x1AC24696,\n\t 0xCDB30AEB, 0x532E3054, 0x8FD948E4, 0x6DBC3128,\n\t 0x58EBF2EF, 0x34C6FFEA, 0xFE28ED61, 0xEE7C3C73,\n\t 0x5D4A14D9, 0xE864B7E3, 0x42105D14, 0x203E13E0,\n\t 0x45EEE2B6, 0xA3AAABEA, 0xDB6C4F15, 0xFACB4FD0,\n\t 0xC742F442, 0xEF6ABBB5, 0x654F3B1D, 0x41CD2105,\n\t 0xD81E799E, 0x86854DC7, 0xE44B476A, 0x3D816250,\n\t 0xCF62A1F2, 0x5B8D2646, 0xFC8883A0, 0xC1C7B6A3,\n\t 0x7F1524C3, 0x69CB7492, 0x47848A0B, 0x5692B285,\n\t 0x095BBF00, 0xAD19489D, 0x1462B174, 0x23820E00,\n\t 0x58428D2A, 0x0C55F5EA, 0x1DADF43E, 0x233F7061,\n\t 0x3372F092, 0x8D937E41, 0xD65FECF1, 0x6C223BDB,\n\t 0x7CDE3759, 0xCBEE7460, 0x4085F2A7, 0xCE77326E,\n\t 0xA6078084, 0x19F8509E, 0xE8EFD855, 0x61D99735,\n\t 0xA969A7AA, 0xC50C06C2, 0x5A04ABFC, 0x800BCADC,\n\t 0x9E447A2E, 0xC3453484, 0xFDD56705, 0x0E1E9EC9,\n\t 0xDB73DBD3, 0x105588CD, 0x675FDA79, 0xE3674340,\n\t 0xC5C43465, 0x713E38D8, 0x3D28F89E, 0xF16DFF20,\n\t 0x153E21E7, 0x8FB03D4A, 0xE6E39F2B, 0xDB83ADF7 ],\n\t [ 0xE93D5A68, 0x948140F7, 0xF64C261C, 0x94692934,\n\t 0x411520F7, 0x7602D4F7, 0xBCF46B2E, 0xD4A20068,\n\t 0xD4082471, 0x3320F46A, 0x43B7D4B7, 0x500061AF,\n\t 0x1E39F62E, 0x97244546, 0x14214F74, 0xBF8B8840,\n\t 0x4D95FC1D, 0x96B591AF, 0x70F4DDD3, 0x66A02F45,\n\t 0xBFBC09EC, 0x03BD9785, 0x7FAC6DD0, 0x31CB8504,\n\t 0x96EB27B3, 0x55FD3941, 0xDA2547E6, 0xABCA0A9A,\n\t 0x28507825, 0x530429F4, 0x0A2C86DA, 0xE9B66DFB,\n\t 0x68DC1462, 0xD7486900, 0x680EC0A4, 0x27A18DEE,\n\t 0x4F3FFEA2, 0xE887AD8C, 0xB58CE006, 0x7AF4D6B6,\n\t 0xAACE1E7C, 0xD3375FEC, 0xCE78A399, 0x406B2A42,\n\t 0x20FE9E35, 0xD9F385B9, 0xEE39D7AB, 0x3B124E8B,\n\t 0x1DC9FAF7, 0x4B6D1856, 0x26A36631, 0xEAE397B2,\n\t 0x3A6EFA74, 0xDD5B4332, 0x6841E7F7, 0xCA7820FB,\n\t 0xFB0AF54E, 0xD8FEB397, 0x454056AC, 0xBA489527,\n\t 0x55533A3A, 0x20838D87, 0xFE6BA9B7, 0xD096954B,\n\t 0x55A867BC, 0xA1159A58, 0xCCA92963, 0x99E1DB33,\n\t 0xA62A4A56, 0x3F3125F9, 0x5EF47E1C, 0x9029317C,\n\t 0xFDF8E802, 0x04272F70, 0x80BB155C, 0x05282CE3,\n\t 0x95C11548, 0xE4C66D22, 0x48C1133F, 0xC70F86DC,\n\t 0x07F9C9EE, 0x41041F0F, 0x404779A4, 0x5D886E17,\n\t 0x325F51EB, 0xD59BC0D1, 0xF2BCC18F, 0x41113564,\n\t 0x257B7834, 0x602A9C60, 0xDFF8E8A3, 0x1F636C1B,\n\t 0x0E12B4C2, 0x02E1329E, 0xAF664FD1, 0xCAD18115,\n\t 0x6B2395E0, 0x333E92E1, 0x3B240B62, 0xEEBEB922,\n\t 0x85B2A20E, 0xE6BA0D99, 0xDE720C8C, 0x2DA2F728,\n\t 0xD0127845, 0x95B794FD, 0x647D0862, 0xE7CCF5F0,\n\t 0x5449A36F, 0x877D48FA, 0xC39DFD27, 0xF33E8D1E,\n\t 0x0A476341, 0x992EFF74, 0x3A6F6EAB, 0xF4F8FD37,\n\t 0xA812DC60, 0xA1EBDDF8, 0x991BE14C, 0xDB6E6B0D,\n\t 0xC67B5510, 0x6D672C37, 0x2765D43B, 0xDCD0E804,\n\t 0xF1290DC7, 0xCC00FFA3, 0xB5390F92, 0x690FED0B,\n\t 0x667B9FFB, 0xCEDB7D9C, 0xA091CF0B, 0xD9155EA3,\n\t 0xBB132F88, 0x515BAD24, 0x7B9479BF, 0x763BD6EB,\n\t 0x37392EB3, 0xCC115979, 0x8026E297, 0xF42E312D,\n\t 0x6842ADA7, 0xC66A2B3B, 0x12754CCC, 0x782EF11C,\n\t 0x6A124237, 0xB79251E7, 0x06A1BBE6, 0x4BFB6350,\n\t 0x1A6B1018, 0x11CAEDFA, 0x3D25BDD8, 0xE2E1C3C9,\n\t 0x44421659, 0x0A121386, 0xD90CEC6E, 0xD5ABEA2A,\n\t 0x64AF674E, 0xDA86A85F, 0xBEBFE988, 0x64E4C3FE,\n\t 0x9DBC8057, 0xF0F7C086, 0x60787BF8, 0x6003604D,\n\t 0xD1FD8346, 0xF6381FB0, 0x7745AE04, 0xD736FCCC,\n\t 0x83426B33, 0xF01EAB71, 0xB0804187, 0x3C005E5F,\n\t 0x77A057BE, 0xBDE8AE24, 0x55464299, 0xBF582E61,\n\t 0x4E58F48F, 0xF2DDFDA2, 0xF474EF38, 0x8789BDC2,\n\t 0x5366F9C3, 0xC8B38E74, 0xB475F255, 0x46FCD9B9,\n\t 0x7AEB2661, 0x8B1DDF84, 0x846A0E79, 0x915F95E2,\n\t 0x466E598E, 0x20B45770, 0x8CD55591, 0xC902DE4C,\n\t 0xB90BACE1, 0xBB8205D0, 0x11A86248, 0x7574A99E,\n\t 0xB77F19B6, 0xE0A9DC09, 0x662D09A1, 0xC4324633,\n\t 0xE85A1F02, 0x09F0BE8C, 0x4A99A025, 0x1D6EFE10,\n\t 0x1AB93D1D, 0x0BA5A4DF, 0xA186F20F, 0x2868F169,\n\t 0xDCB7DA83, 0x573906FE, 0xA1E2CE9B, 0x4FCD7F52,\n\t 0x50115E01, 0xA70683FA, 0xA002B5C4, 0x0DE6D027,\n\t 0x9AF88C27, 0x773F8641, 0xC3604C06, 0x61A806B5,\n\t 0xF0177A28, 0xC0F586E0, 0x006058AA, 0x30DC7D62,\n\t 0x11E69ED7, 0x2338EA63, 0x53C2DD94, 0xC2C21634,\n\t 0xBBCBEE56, 0x90BCB6DE, 0xEBFC7DA1, 0xCE591D76,\n\t 0x6F05E409, 0x4B7C0188, 0x39720A3D, 0x7C927C24,\n\t 0x86E3725F, 0x724D9DB9, 0x1AC15BB4, 0xD39EB8FC,\n\t 0xED545578, 0x08FCA5B5, 0xD83D7CD3, 0x4DAD0FC4,\n\t 0x1E50EF5E, 0xB161E6F8, 0xA28514D9, 0x6C51133C,\n\t 0x6FD5C7E7, 0x56E14EC4, 0x362ABFCE, 0xDDC6C837,\n\t 0xD79A3234, 0x92638212, 0x670EFA8E, 0x406000E0 ],\n\t [ 0x3A39CE37, 0xD3FAF5CF, 0xABC27737, 0x5AC52D1B,\n\t 0x5CB0679E, 0x4FA33742, 0xD3822740, 0x99BC9BBE,\n\t 0xD5118E9D, 0xBF0F7315, 0xD62D1C7E, 0xC700C47B,\n\t 0xB78C1B6B, 0x21A19045, 0xB26EB1BE, 0x6A366EB4,\n\t 0x5748AB2F, 0xBC946E79, 0xC6A376D2, 0x6549C2C8,\n\t 0x530FF8EE, 0x468DDE7D, 0xD5730A1D, 0x4CD04DC6,\n\t 0x2939BBDB, 0xA9BA4650, 0xAC9526E8, 0xBE5EE304,\n\t 0xA1FAD5F0, 0x6A2D519A, 0x63EF8CE2, 0x9A86EE22,\n\t 0xC089C2B8, 0x43242EF6, 0xA51E03AA, 0x9CF2D0A4,\n\t 0x83C061BA, 0x9BE96A4D, 0x8FE51550, 0xBA645BD6,\n\t 0x2826A2F9, 0xA73A3AE1, 0x4BA99586, 0xEF5562E9,\n\t 0xC72FEFD3, 0xF752F7DA, 0x3F046F69, 0x77FA0A59,\n\t 0x80E4A915, 0x87B08601, 0x9B09E6AD, 0x3B3EE593,\n\t 0xE990FD5A, 0x9E34D797, 0x2CF0B7D9, 0x022B8B51,\n\t 0x96D5AC3A, 0x017DA67D, 0xD1CF3ED6, 0x7C7D2D28,\n\t 0x1F9F25CF, 0xADF2B89B, 0x5AD6B472, 0x5A88F54C,\n\t 0xE029AC71, 0xE019A5E6, 0x47B0ACFD, 0xED93FA9B,\n\t 0xE8D3C48D, 0x283B57CC, 0xF8D56629, 0x79132E28,\n\t 0x785F0191, 0xED756055, 0xF7960E44, 0xE3D35E8C,\n\t 0x15056DD4, 0x88F46DBA, 0x03A16125, 0x0564F0BD,\n\t 0xC3EB9E15, 0x3C9057A2, 0x97271AEC, 0xA93A072A,\n\t 0x1B3F6D9B, 0x1E6321F5, 0xF59C66FB, 0x26DCF319,\n\t 0x7533D928, 0xB155FDF5, 0x03563482, 0x8ABA3CBB,\n\t 0x28517711, 0xC20AD9F8, 0xABCC5167, 0xCCAD925F,\n\t 0x4DE81751, 0x3830DC8E, 0x379D5862, 0x9320F991,\n\t 0xEA7A90C2, 0xFB3E7BCE, 0x5121CE64, 0x774FBE32,\n\t 0xA8B6E37E, 0xC3293D46, 0x48DE5369, 0x6413E680,\n\t 0xA2AE0810, 0xDD6DB224, 0x69852DFD, 0x09072166,\n\t 0xB39A460A, 0x6445C0DD, 0x586CDECF, 0x1C20C8AE,\n\t 0x5BBEF7DD, 0x1B588D40, 0xCCD2017F, 0x6BB4E3BB,\n\t 0xDDA26A7E, 0x3A59FF45, 0x3E350A44, 0xBCB4CDD5,\n\t 0x72EACEA8, 0xFA6484BB, 0x8D6612AE, 0xBF3C6F47,\n\t 0xD29BE463, 0x542F5D9E, 0xAEC2771B, 0xF64E6370,\n\t 0x740E0D8D, 0xE75B1357, 0xF8721671, 0xAF537D5D,\n\t 0x4040CB08, 0x4EB4E2CC, 0x34D2466A, 0x0115AF84,\n\t 0xE1B00428, 0x95983A1D, 0x06B89FB4, 0xCE6EA048,\n\t 0x6F3F3B82, 0x3520AB82, 0x011A1D4B, 0x277227F8,\n\t 0x611560B1, 0xE7933FDC, 0xBB3A792B, 0x344525BD,\n\t 0xA08839E1, 0x51CE794B, 0x2F32C9B7, 0xA01FBAC9,\n\t 0xE01CC87E, 0xBCC7D1F6, 0xCF0111C3, 0xA1E8AAC7,\n\t 0x1A908749, 0xD44FBD9A, 0xD0DADECB, 0xD50ADA38,\n\t 0x0339C32A, 0xC6913667, 0x8DF9317C, 0xE0B12B4F,\n\t 0xF79E59B7, 0x43F5BB3A, 0xF2D519FF, 0x27D9459C,\n\t 0xBF97222C, 0x15E6FC2A, 0x0F91FC71, 0x9B941525,\n\t 0xFAE59361, 0xCEB69CEB, 0xC2A86459, 0x12BAA8D1,\n\t 0xB6C1075E, 0xE3056A0C, 0x10D25065, 0xCB03A442,\n\t 0xE0EC6E0E, 0x1698DB3B, 0x4C98A0BE, 0x3278E964,\n\t 0x9F1F9532, 0xE0D392DF, 0xD3A0342B, 0x8971F21E,\n\t 0x1B0A7441, 0x4BA3348C, 0xC5BE7120, 0xC37632D8,\n\t 0xDF359F8D, 0x9B992F2E, 0xE60B6F47, 0x0FE3F11D,\n\t 0xE54CDA54, 0x1EDAD891, 0xCE6279CF, 0xCD3E7E6F,\n\t 0x1618B166, 0xFD2C1D05, 0x848FD2C5, 0xF6FB2299,\n\t 0xF523F357, 0xA6327623, 0x93A83531, 0x56CCCD02,\n\t 0xACF08162, 0x5A75EBB5, 0x6E163697, 0x88D273CC,\n\t 0xDE966292, 0x81B949D0, 0x4C50901B, 0x71C65614,\n\t 0xE6C6C7BD, 0x327A140A, 0x45E1D006, 0xC3F27B9A,\n\t 0xC9AA53FD, 0x62A80F00, 0xBB25BFE2, 0x35BDD2F6,\n\t 0x71126905, 0xB2040222, 0xB6CBCF7C, 0xCD769C2B,\n\t 0x53113EC0, 0x1640E3D3, 0x38ABBD60, 0x2547ADF0,\n\t 0xBA38209C, 0xF746CE76, 0x77AFA1C5, 0x20756060,\n\t 0x85CBFE4E, 0x8AE88DD8, 0x7AAAF9B0, 0x4CF9AA7E,\n\t 0x1948C25C, 0x02FB8A8C, 0x01C36AE4, 0xD6EBE1F9,\n\t 0x90D4F869, 0xA65CDEA0, 0x3F09252D, 0xC208E69F,\n\t 0xB74E6132, 0xCE77E25B, 0x578FDFE3, 0x3AC372E6 ]\n\t ];\n\n\t var BLOWFISH_CTX = {\n\t pbox: [],\n\t sbox: []\n\t }\n\n\t function F(ctx, x){\n\t let a = (x >> 24) & 0xFF;\n\t let b = (x >> 16) & 0xFF;\n\t let c = (x >> 8) & 0xFF;\n\t let d = x & 0xFF;\n\n\t let y = ctx.sbox[0][a] + ctx.sbox[1][b];\n\t y = y ^ ctx.sbox[2][c];\n\t y = y + ctx.sbox[3][d];\n\n\t return y;\n\t }\n\n\t function BlowFish_Encrypt(ctx, left, right){\n\t let Xl = left;\n\t let Xr = right;\n\t let temp;\n\n\t for(let i = 0; i < N; ++i){\n\t Xl = Xl ^ ctx.pbox[i];\n\t Xr = F(ctx, Xl) ^ Xr;\n\n\t temp = Xl;\n\t Xl = Xr;\n\t Xr = temp;\n\t }\n\n\t temp = Xl;\n\t Xl = Xr;\n\t Xr = temp;\n\n\t Xr = Xr ^ ctx.pbox[N];\n\t Xl = Xl ^ ctx.pbox[N + 1];\n\n\t return {left: Xl, right: Xr};\n\t }\n\n\t function BlowFish_Decrypt(ctx, left, right){\n\t let Xl = left;\n\t let Xr = right;\n\t let temp;\n\n\t for(let i = N + 1; i > 1; --i){\n\t Xl = Xl ^ ctx.pbox[i];\n\t Xr = F(ctx, Xl) ^ Xr;\n\n\t temp = Xl;\n\t Xl = Xr;\n\t Xr = temp;\n\t }\n\n\t temp = Xl;\n\t Xl = Xr;\n\t Xr = temp;\n\n\t Xr = Xr ^ ctx.pbox[1];\n\t Xl = Xl ^ ctx.pbox[0];\n\n\t return {left: Xl, right: Xr};\n\t }\n\n\t /**\n\t * Initialization ctx's pbox and sbox.\n\t *\n\t * @param {Object} ctx The object has pbox and sbox.\n\t * @param {Array} key An array of 32-bit words.\n\t * @param {int} keysize The length of the key.\n\t *\n\t * @example\n\t *\n\t * BlowFishInit(BLOWFISH_CTX, key, 128/32);\n\t */\n\t function BlowFishInit(ctx, key, keysize)\n\t {\n\t for(let Row = 0; Row < 4; Row++)\n\t {\n\t ctx.sbox[Row] = [];\n\t for(let Col = 0; Col < 256; Col++)\n\t {\n\t ctx.sbox[Row][Col] = ORIG_S[Row][Col];\n\t }\n\t }\n\n\t let keyIndex = 0;\n\t for(let index = 0; index < N + 2; index++)\n\t {\n\t ctx.pbox[index] = ORIG_P[index] ^ key[keyIndex];\n\t keyIndex++;\n\t if(keyIndex >= keysize)\n\t {\n\t keyIndex = 0;\n\t }\n\t }\n\n\t let Data1 = 0;\n\t let Data2 = 0;\n\t let res = 0;\n\t for(let i = 0; i < N + 2; i += 2)\n\t {\n\t res = BlowFish_Encrypt(ctx, Data1, Data2);\n\t Data1 = res.left;\n\t Data2 = res.right;\n\t ctx.pbox[i] = Data1;\n\t ctx.pbox[i + 1] = Data2;\n\t }\n\n\t for(let i = 0; i < 4; i++)\n\t {\n\t for(let j = 0; j < 256; j += 2)\n\t {\n\t res = BlowFish_Encrypt(ctx, Data1, Data2);\n\t Data1 = res.left;\n\t Data2 = res.right;\n\t ctx.sbox[i][j] = Data1;\n\t ctx.sbox[i][j + 1] = Data2;\n\t }\n\t }\n\n\t return true;\n\t }\n\n\t /**\n\t * Blowfish block cipher algorithm.\n\t */\n\t var Blowfish = C_algo.Blowfish = BlockCipher.extend({\n\t _doReset: function () {\n\t // Skip reset of nRounds has been set before and key did not change\n\t if (this._keyPriorReset === this._key) {\n\t return;\n\t }\n\n\t // Shortcuts\n\t var key = this._keyPriorReset = this._key;\n\t var keyWords = key.words;\n\t var keySize = key.sigBytes / 4;\n\n\t //Initialization pbox and sbox\n\t BlowFishInit(BLOWFISH_CTX, keyWords, keySize);\n\t },\n\n\t encryptBlock: function (M, offset) {\n\t var res = BlowFish_Encrypt(BLOWFISH_CTX, M[offset], M[offset + 1]);\n\t M[offset] = res.left;\n\t M[offset + 1] = res.right;\n\t },\n\n\t decryptBlock: function (M, offset) {\n\t var res = BlowFish_Decrypt(BLOWFISH_CTX, M[offset], M[offset + 1]);\n\t M[offset] = res.left;\n\t M[offset + 1] = res.right;\n\t },\n\n\t blockSize: 64/32,\n\n\t keySize: 128/32,\n\n\t ivSize: 64/32\n\t });\n\n\t /**\n\t * Shortcut functions to the cipher's object interface.\n\t *\n\t * @example\n\t *\n\t * var ciphertext = CryptoJS.Blowfish.encrypt(message, key, cfg);\n\t * var plaintext = CryptoJS.Blowfish.decrypt(ciphertext, key, cfg);\n\t */\n\t C.Blowfish = BlockCipher._createHelper(Blowfish);\n\t}());\n\n\n\treturn CryptoJS.Blowfish;\n\n}));",";(function (root, factory, undef) {\n\tif (typeof exports === \"object\") {\n\t\t// CommonJS\n\t\tmodule.exports = exports = factory(require(\"./core\"), require(\"./evpkdf\"));\n\t}\n\telse if (typeof define === \"function\" && define.amd) {\n\t\t// AMD\n\t\tdefine([\"./core\", \"./evpkdf\"], factory);\n\t}\n\telse {\n\t\t// Global (browser)\n\t\tfactory(root.CryptoJS);\n\t}\n}(this, function (CryptoJS) {\n\n\t/**\n\t * Cipher core components.\n\t */\n\tCryptoJS.lib.Cipher || (function (undefined) {\n\t // Shortcuts\n\t var C = CryptoJS;\n\t var C_lib = C.lib;\n\t var Base = C_lib.Base;\n\t var WordArray = C_lib.WordArray;\n\t var BufferedBlockAlgorithm = C_lib.BufferedBlockAlgorithm;\n\t var C_enc = C.enc;\n\t var Utf8 = C_enc.Utf8;\n\t var Base64 = C_enc.Base64;\n\t var C_algo = C.algo;\n\t var EvpKDF = C_algo.EvpKDF;\n\n\t /**\n\t * Abstract base cipher template.\n\t *\n\t * @property {number} keySize This cipher's key size. Default: 4 (128 bits)\n\t * @property {number} ivSize This cipher's IV size. Default: 4 (128 bits)\n\t * @property {number} _ENC_XFORM_MODE A constant representing encryption mode.\n\t * @property {number} _DEC_XFORM_MODE A constant representing decryption mode.\n\t */\n\t var Cipher = C_lib.Cipher = BufferedBlockAlgorithm.extend({\n\t /**\n\t * Configuration options.\n\t *\n\t * @property {WordArray} iv The IV to use for this operation.\n\t */\n\t cfg: Base.extend(),\n\n\t /**\n\t * Creates this cipher in encryption mode.\n\t *\n\t * @param {WordArray} key The key.\n\t * @param {Object} cfg (Optional) The configuration options to use for this operation.\n\t *\n\t * @return {Cipher} A cipher instance.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var cipher = CryptoJS.algo.AES.createEncryptor(keyWordArray, { iv: ivWordArray });\n\t */\n\t createEncryptor: function (key, cfg) {\n\t return this.create(this._ENC_XFORM_MODE, key, cfg);\n\t },\n\n\t /**\n\t * Creates this cipher in decryption mode.\n\t *\n\t * @param {WordArray} key The key.\n\t * @param {Object} cfg (Optional) The configuration options to use for this operation.\n\t *\n\t * @return {Cipher} A cipher instance.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var cipher = CryptoJS.algo.AES.createDecryptor(keyWordArray, { iv: ivWordArray });\n\t */\n\t createDecryptor: function (key, cfg) {\n\t return this.create(this._DEC_XFORM_MODE, key, cfg);\n\t },\n\n\t /**\n\t * Initializes a newly created cipher.\n\t *\n\t * @param {number} xformMode Either the encryption or decryption transormation mode constant.\n\t * @param {WordArray} key The key.\n\t * @param {Object} cfg (Optional) The configuration options to use for this operation.\n\t *\n\t * @example\n\t *\n\t * var cipher = CryptoJS.algo.AES.create(CryptoJS.algo.AES._ENC_XFORM_MODE, keyWordArray, { iv: ivWordArray });\n\t */\n\t init: function (xformMode, key, cfg) {\n\t // Apply config defaults\n\t this.cfg = this.cfg.extend(cfg);\n\n\t // Store transform mode and key\n\t this._xformMode = xformMode;\n\t this._key = key;\n\n\t // Set initial values\n\t this.reset();\n\t },\n\n\t /**\n\t * Resets this cipher to its initial state.\n\t *\n\t * @example\n\t *\n\t * cipher.reset();\n\t */\n\t reset: function () {\n\t // Reset data buffer\n\t BufferedBlockAlgorithm.reset.call(this);\n\n\t // Perform concrete-cipher logic\n\t this._doReset();\n\t },\n\n\t /**\n\t * Adds data to be encrypted or decrypted.\n\t *\n\t * @param {WordArray|string} dataUpdate The data to encrypt or decrypt.\n\t *\n\t * @return {WordArray} The data after processing.\n\t *\n\t * @example\n\t *\n\t * var encrypted = cipher.process('data');\n\t * var encrypted = cipher.process(wordArray);\n\t */\n\t process: function (dataUpdate) {\n\t // Append\n\t this._append(dataUpdate);\n\n\t // Process available blocks\n\t return this._process();\n\t },\n\n\t /**\n\t * Finalizes the encryption or decryption process.\n\t * Note that the finalize operation is effectively a destructive, read-once operation.\n\t *\n\t * @param {WordArray|string} dataUpdate The final data to encrypt or decrypt.\n\t *\n\t * @return {WordArray} The data after final processing.\n\t *\n\t * @example\n\t *\n\t * var encrypted = cipher.finalize();\n\t * var encrypted = cipher.finalize('data');\n\t * var encrypted = cipher.finalize(wordArray);\n\t */\n\t finalize: function (dataUpdate) {\n\t // Final data update\n\t if (dataUpdate) {\n\t this._append(dataUpdate);\n\t }\n\n\t // Perform concrete-cipher logic\n\t var finalProcessedData = this._doFinalize();\n\n\t return finalProcessedData;\n\t },\n\n\t keySize: 128/32,\n\n\t ivSize: 128/32,\n\n\t _ENC_XFORM_MODE: 1,\n\n\t _DEC_XFORM_MODE: 2,\n\n\t /**\n\t * Creates shortcut functions to a cipher's object interface.\n\t *\n\t * @param {Cipher} cipher The cipher to create a helper for.\n\t *\n\t * @return {Object} An object with encrypt and decrypt shortcut functions.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var AES = CryptoJS.lib.Cipher._createHelper(CryptoJS.algo.AES);\n\t */\n\t _createHelper: (function () {\n\t function selectCipherStrategy(key) {\n\t if (typeof key == 'string') {\n\t return PasswordBasedCipher;\n\t } else {\n\t return SerializableCipher;\n\t }\n\t }\n\n\t return function (cipher) {\n\t return {\n\t encrypt: function (message, key, cfg) {\n\t return selectCipherStrategy(key).encrypt(cipher, message, key, cfg);\n\t },\n\n\t decrypt: function (ciphertext, key, cfg) {\n\t return selectCipherStrategy(key).decrypt(cipher, ciphertext, key, cfg);\n\t }\n\t };\n\t };\n\t }())\n\t });\n\n\t /**\n\t * Abstract base stream cipher template.\n\t *\n\t * @property {number} blockSize The number of 32-bit words this cipher operates on. Default: 1 (32 bits)\n\t */\n\t var StreamCipher = C_lib.StreamCipher = Cipher.extend({\n\t _doFinalize: function () {\n\t // Process partial blocks\n\t var finalProcessedBlocks = this._process(!!'flush');\n\n\t return finalProcessedBlocks;\n\t },\n\n\t blockSize: 1\n\t });\n\n\t /**\n\t * Mode namespace.\n\t */\n\t var C_mode = C.mode = {};\n\n\t /**\n\t * Abstract base block cipher mode template.\n\t */\n\t var BlockCipherMode = C_lib.BlockCipherMode = Base.extend({\n\t /**\n\t * Creates this mode for encryption.\n\t *\n\t * @param {Cipher} cipher A block cipher instance.\n\t * @param {Array} iv The IV words.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var mode = CryptoJS.mode.CBC.createEncryptor(cipher, iv.words);\n\t */\n\t createEncryptor: function (cipher, iv) {\n\t return this.Encryptor.create(cipher, iv);\n\t },\n\n\t /**\n\t * Creates this mode for decryption.\n\t *\n\t * @param {Cipher} cipher A block cipher instance.\n\t * @param {Array} iv The IV words.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var mode = CryptoJS.mode.CBC.createDecryptor(cipher, iv.words);\n\t */\n\t createDecryptor: function (cipher, iv) {\n\t return this.Decryptor.create(cipher, iv);\n\t },\n\n\t /**\n\t * Initializes a newly created mode.\n\t *\n\t * @param {Cipher} cipher A block cipher instance.\n\t * @param {Array} iv The IV words.\n\t *\n\t * @example\n\t *\n\t * var mode = CryptoJS.mode.CBC.Encryptor.create(cipher, iv.words);\n\t */\n\t init: function (cipher, iv) {\n\t this._cipher = cipher;\n\t this._iv = iv;\n\t }\n\t });\n\n\t /**\n\t * Cipher Block Chaining mode.\n\t */\n\t var CBC = C_mode.CBC = (function () {\n\t /**\n\t * Abstract base CBC mode.\n\t */\n\t var CBC = BlockCipherMode.extend();\n\n\t /**\n\t * CBC encryptor.\n\t */\n\t CBC.Encryptor = CBC.extend({\n\t /**\n\t * Processes the data block at offset.\n\t *\n\t * @param {Array} words The data words to operate on.\n\t * @param {number} offset The offset where the block starts.\n\t *\n\t * @example\n\t *\n\t * mode.processBlock(data.words, offset);\n\t */\n\t processBlock: function (words, offset) {\n\t // Shortcuts\n\t var cipher = this._cipher;\n\t var blockSize = cipher.blockSize;\n\n\t // XOR and encrypt\n\t xorBlock.call(this, words, offset, blockSize);\n\t cipher.encryptBlock(words, offset);\n\n\t // Remember this block to use with next block\n\t this._prevBlock = words.slice(offset, offset + blockSize);\n\t }\n\t });\n\n\t /**\n\t * CBC decryptor.\n\t */\n\t CBC.Decryptor = CBC.extend({\n\t /**\n\t * Processes the data block at offset.\n\t *\n\t * @param {Array} words The data words to operate on.\n\t * @param {number} offset The offset where the block starts.\n\t *\n\t * @example\n\t *\n\t * mode.processBlock(data.words, offset);\n\t */\n\t processBlock: function (words, offset) {\n\t // Shortcuts\n\t var cipher = this._cipher;\n\t var blockSize = cipher.blockSize;\n\n\t // Remember this block to use with next block\n\t var thisBlock = words.slice(offset, offset + blockSize);\n\n\t // Decrypt and XOR\n\t cipher.decryptBlock(words, offset);\n\t xorBlock.call(this, words, offset, blockSize);\n\n\t // This block becomes the previous block\n\t this._prevBlock = thisBlock;\n\t }\n\t });\n\n\t function xorBlock(words, offset, blockSize) {\n\t var block;\n\n\t // Shortcut\n\t var iv = this._iv;\n\n\t // Choose mixing block\n\t if (iv) {\n\t block = iv;\n\n\t // Remove IV for subsequent blocks\n\t this._iv = undefined;\n\t } else {\n\t block = this._prevBlock;\n\t }\n\n\t // XOR blocks\n\t for (var i = 0; i < blockSize; i++) {\n\t words[offset + i] ^= block[i];\n\t }\n\t }\n\n\t return CBC;\n\t }());\n\n\t /**\n\t * Padding namespace.\n\t */\n\t var C_pad = C.pad = {};\n\n\t /**\n\t * PKCS #5/7 padding strategy.\n\t */\n\t var Pkcs7 = C_pad.Pkcs7 = {\n\t /**\n\t * Pads data using the algorithm defined in PKCS #5/7.\n\t *\n\t * @param {WordArray} data The data to pad.\n\t * @param {number} blockSize The multiple that the data should be padded to.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * CryptoJS.pad.Pkcs7.pad(wordArray, 4);\n\t */\n\t pad: function (data, blockSize) {\n\t // Shortcut\n\t var blockSizeBytes = blockSize * 4;\n\n\t // Count padding bytes\n\t var nPaddingBytes = blockSizeBytes - data.sigBytes % blockSizeBytes;\n\n\t // Create padding word\n\t var paddingWord = (nPaddingBytes << 24) | (nPaddingBytes << 16) | (nPaddingBytes << 8) | nPaddingBytes;\n\n\t // Create padding\n\t var paddingWords = [];\n\t for (var i = 0; i < nPaddingBytes; i += 4) {\n\t paddingWords.push(paddingWord);\n\t }\n\t var padding = WordArray.create(paddingWords, nPaddingBytes);\n\n\t // Add padding\n\t data.concat(padding);\n\t },\n\n\t /**\n\t * Unpads data that had been padded using the algorithm defined in PKCS #5/7.\n\t *\n\t * @param {WordArray} data The data to unpad.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * CryptoJS.pad.Pkcs7.unpad(wordArray);\n\t */\n\t unpad: function (data) {\n\t // Get number of padding bytes from last byte\n\t var nPaddingBytes = data.words[(data.sigBytes - 1) >>> 2] & 0xff;\n\n\t // Remove padding\n\t data.sigBytes -= nPaddingBytes;\n\t }\n\t };\n\n\t /**\n\t * Abstract base block cipher template.\n\t *\n\t * @property {number} blockSize The number of 32-bit words this cipher operates on. Default: 4 (128 bits)\n\t */\n\t var BlockCipher = C_lib.BlockCipher = Cipher.extend({\n\t /**\n\t * Configuration options.\n\t *\n\t * @property {Mode} mode The block mode to use. Default: CBC\n\t * @property {Padding} padding The padding strategy to use. Default: Pkcs7\n\t */\n\t cfg: Cipher.cfg.extend({\n\t mode: CBC,\n\t padding: Pkcs7\n\t }),\n\n\t reset: function () {\n\t var modeCreator;\n\n\t // Reset cipher\n\t Cipher.reset.call(this);\n\n\t // Shortcuts\n\t var cfg = this.cfg;\n\t var iv = cfg.iv;\n\t var mode = cfg.mode;\n\n\t // Reset block mode\n\t if (this._xformMode == this._ENC_XFORM_MODE) {\n\t modeCreator = mode.createEncryptor;\n\t } else /* if (this._xformMode == this._DEC_XFORM_MODE) */ {\n\t modeCreator = mode.createDecryptor;\n\t // Keep at least one block in the buffer for unpadding\n\t this._minBufferSize = 1;\n\t }\n\n\t if (this._mode && this._mode.__creator == modeCreator) {\n\t this._mode.init(this, iv && iv.words);\n\t } else {\n\t this._mode = modeCreator.call(mode, this, iv && iv.words);\n\t this._mode.__creator = modeCreator;\n\t }\n\t },\n\n\t _doProcessBlock: function (words, offset) {\n\t this._mode.processBlock(words, offset);\n\t },\n\n\t _doFinalize: function () {\n\t var finalProcessedBlocks;\n\n\t // Shortcut\n\t var padding = this.cfg.padding;\n\n\t // Finalize\n\t if (this._xformMode == this._ENC_XFORM_MODE) {\n\t // Pad data\n\t padding.pad(this._data, this.blockSize);\n\n\t // Process final blocks\n\t finalProcessedBlocks = this._process(!!'flush');\n\t } else /* if (this._xformMode == this._DEC_XFORM_MODE) */ {\n\t // Process final blocks\n\t finalProcessedBlocks = this._process(!!'flush');\n\n\t // Unpad data\n\t padding.unpad(finalProcessedBlocks);\n\t }\n\n\t return finalProcessedBlocks;\n\t },\n\n\t blockSize: 128/32\n\t });\n\n\t /**\n\t * A collection of cipher parameters.\n\t *\n\t * @property {WordArray} ciphertext The raw ciphertext.\n\t * @property {WordArray} key The key to this ciphertext.\n\t * @property {WordArray} iv The IV used in the ciphering operation.\n\t * @property {WordArray} salt The salt used with a key derivation function.\n\t * @property {Cipher} algorithm The cipher algorithm.\n\t * @property {Mode} mode The block mode used in the ciphering operation.\n\t * @property {Padding} padding The padding scheme used in the ciphering operation.\n\t * @property {number} blockSize The block size of the cipher.\n\t * @property {Format} formatter The default formatting strategy to convert this cipher params object to a string.\n\t */\n\t var CipherParams = C_lib.CipherParams = Base.extend({\n\t /**\n\t * Initializes a newly created cipher params object.\n\t *\n\t * @param {Object} cipherParams An object with any of the possible cipher parameters.\n\t *\n\t * @example\n\t *\n\t * var cipherParams = CryptoJS.lib.CipherParams.create({\n\t * ciphertext: ciphertextWordArray,\n\t * key: keyWordArray,\n\t * iv: ivWordArray,\n\t * salt: saltWordArray,\n\t * algorithm: CryptoJS.algo.AES,\n\t * mode: CryptoJS.mode.CBC,\n\t * padding: CryptoJS.pad.PKCS7,\n\t * blockSize: 4,\n\t * formatter: CryptoJS.format.OpenSSL\n\t * });\n\t */\n\t init: function (cipherParams) {\n\t this.mixIn(cipherParams);\n\t },\n\n\t /**\n\t * Converts this cipher params object to a string.\n\t *\n\t * @param {Format} formatter (Optional) The formatting strategy to use.\n\t *\n\t * @return {string} The stringified cipher params.\n\t *\n\t * @throws Error If neither the formatter nor the default formatter is set.\n\t *\n\t * @example\n\t *\n\t * var string = cipherParams + '';\n\t * var string = cipherParams.toString();\n\t * var string = cipherParams.toString(CryptoJS.format.OpenSSL);\n\t */\n\t toString: function (formatter) {\n\t return (formatter || this.formatter).stringify(this);\n\t }\n\t });\n\n\t /**\n\t * Format namespace.\n\t */\n\t var C_format = C.format = {};\n\n\t /**\n\t * OpenSSL formatting strategy.\n\t */\n\t var OpenSSLFormatter = C_format.OpenSSL = {\n\t /**\n\t * Converts a cipher params object to an OpenSSL-compatible string.\n\t *\n\t * @param {CipherParams} cipherParams The cipher params object.\n\t *\n\t * @return {string} The OpenSSL-compatible string.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var openSSLString = CryptoJS.format.OpenSSL.stringify(cipherParams);\n\t */\n\t stringify: function (cipherParams) {\n\t var wordArray;\n\n\t // Shortcuts\n\t var ciphertext = cipherParams.ciphertext;\n\t var salt = cipherParams.salt;\n\n\t // Format\n\t if (salt) {\n\t wordArray = WordArray.create([0x53616c74, 0x65645f5f]).concat(salt).concat(ciphertext);\n\t } else {\n\t wordArray = ciphertext;\n\t }\n\n\t return wordArray.toString(Base64);\n\t },\n\n\t /**\n\t * Converts an OpenSSL-compatible string to a cipher params object.\n\t *\n\t * @param {string} openSSLStr The OpenSSL-compatible string.\n\t *\n\t * @return {CipherParams} The cipher params object.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var cipherParams = CryptoJS.format.OpenSSL.parse(openSSLString);\n\t */\n\t parse: function (openSSLStr) {\n\t var salt;\n\n\t // Parse base64\n\t var ciphertext = Base64.parse(openSSLStr);\n\n\t // Shortcut\n\t var ciphertextWords = ciphertext.words;\n\n\t // Test for salt\n\t if (ciphertextWords[0] == 0x53616c74 && ciphertextWords[1] == 0x65645f5f) {\n\t // Extract salt\n\t salt = WordArray.create(ciphertextWords.slice(2, 4));\n\n\t // Remove salt from ciphertext\n\t ciphertextWords.splice(0, 4);\n\t ciphertext.sigBytes -= 16;\n\t }\n\n\t return CipherParams.create({ ciphertext: ciphertext, salt: salt });\n\t }\n\t };\n\n\t /**\n\t * A cipher wrapper that returns ciphertext as a serializable cipher params object.\n\t */\n\t var SerializableCipher = C_lib.SerializableCipher = Base.extend({\n\t /**\n\t * Configuration options.\n\t *\n\t * @property {Formatter} format The formatting strategy to convert cipher param objects to and from a string. Default: OpenSSL\n\t */\n\t cfg: Base.extend({\n\t format: OpenSSLFormatter\n\t }),\n\n\t /**\n\t * Encrypts a message.\n\t *\n\t * @param {Cipher} cipher The cipher algorithm to use.\n\t * @param {WordArray|string} message The message to encrypt.\n\t * @param {WordArray} key The key.\n\t * @param {Object} cfg (Optional) The configuration options to use for this operation.\n\t *\n\t * @return {CipherParams} A cipher params object.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var ciphertextParams = CryptoJS.lib.SerializableCipher.encrypt(CryptoJS.algo.AES, message, key);\n\t * var ciphertextParams = CryptoJS.lib.SerializableCipher.encrypt(CryptoJS.algo.AES, message, key, { iv: iv });\n\t * var ciphertextParams = CryptoJS.lib.SerializableCipher.encrypt(CryptoJS.algo.AES, message, key, { iv: iv, format: CryptoJS.format.OpenSSL });\n\t */\n\t encrypt: function (cipher, message, key, cfg) {\n\t // Apply config defaults\n\t cfg = this.cfg.extend(cfg);\n\n\t // Encrypt\n\t var encryptor = cipher.createEncryptor(key, cfg);\n\t var ciphertext = encryptor.finalize(message);\n\n\t // Shortcut\n\t var cipherCfg = encryptor.cfg;\n\n\t // Create and return serializable cipher params\n\t return CipherParams.create({\n\t ciphertext: ciphertext,\n\t key: key,\n\t iv: cipherCfg.iv,\n\t algorithm: cipher,\n\t mode: cipherCfg.mode,\n\t padding: cipherCfg.padding,\n\t blockSize: cipher.blockSize,\n\t formatter: cfg.format\n\t });\n\t },\n\n\t /**\n\t * Decrypts serialized ciphertext.\n\t *\n\t * @param {Cipher} cipher The cipher algorithm to use.\n\t * @param {CipherParams|string} ciphertext The ciphertext to decrypt.\n\t * @param {WordArray} key The key.\n\t * @param {Object} cfg (Optional) The configuration options to use for this operation.\n\t *\n\t * @return {WordArray} The plaintext.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var plaintext = CryptoJS.lib.SerializableCipher.decrypt(CryptoJS.algo.AES, formattedCiphertext, key, { iv: iv, format: CryptoJS.format.OpenSSL });\n\t * var plaintext = CryptoJS.lib.SerializableCipher.decrypt(CryptoJS.algo.AES, ciphertextParams, key, { iv: iv, format: CryptoJS.format.OpenSSL });\n\t */\n\t decrypt: function (cipher, ciphertext, key, cfg) {\n\t // Apply config defaults\n\t cfg = this.cfg.extend(cfg);\n\n\t // Convert string to CipherParams\n\t ciphertext = this._parse(ciphertext, cfg.format);\n\n\t // Decrypt\n\t var plaintext = cipher.createDecryptor(key, cfg).finalize(ciphertext.ciphertext);\n\n\t return plaintext;\n\t },\n\n\t /**\n\t * Converts serialized ciphertext to CipherParams,\n\t * else assumed CipherParams already and returns ciphertext unchanged.\n\t *\n\t * @param {CipherParams|string} ciphertext The ciphertext.\n\t * @param {Formatter} format The formatting strategy to use to parse serialized ciphertext.\n\t *\n\t * @return {CipherParams} The unserialized ciphertext.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var ciphertextParams = CryptoJS.lib.SerializableCipher._parse(ciphertextStringOrParams, format);\n\t */\n\t _parse: function (ciphertext, format) {\n\t if (typeof ciphertext == 'string') {\n\t return format.parse(ciphertext, this);\n\t } else {\n\t return ciphertext;\n\t }\n\t }\n\t });\n\n\t /**\n\t * Key derivation function namespace.\n\t */\n\t var C_kdf = C.kdf = {};\n\n\t /**\n\t * OpenSSL key derivation function.\n\t */\n\t var OpenSSLKdf = C_kdf.OpenSSL = {\n\t /**\n\t * Derives a key and IV from a password.\n\t *\n\t * @param {string} password The password to derive from.\n\t * @param {number} keySize The size in words of the key to generate.\n\t * @param {number} ivSize The size in words of the IV to generate.\n\t * @param {WordArray|string} salt (Optional) A 64-bit salt to use. If omitted, a salt will be generated randomly.\n\t *\n\t * @return {CipherParams} A cipher params object with the key, IV, and salt.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var derivedParams = CryptoJS.kdf.OpenSSL.execute('Password', 256/32, 128/32);\n\t * var derivedParams = CryptoJS.kdf.OpenSSL.execute('Password', 256/32, 128/32, 'saltsalt');\n\t */\n\t execute: function (password, keySize, ivSize, salt, hasher) {\n\t // Generate random salt\n\t if (!salt) {\n\t salt = WordArray.random(64/8);\n\t }\n\n\t // Derive key and IV\n\t if (!hasher) {\n\t var key = EvpKDF.create({ keySize: keySize + ivSize }).compute(password, salt);\n\t } else {\n\t var key = EvpKDF.create({ keySize: keySize + ivSize, hasher: hasher }).compute(password, salt);\n\t }\n\n\n\t // Separate key and IV\n\t var iv = WordArray.create(key.words.slice(keySize), ivSize * 4);\n\t key.sigBytes = keySize * 4;\n\n\t // Return params\n\t return CipherParams.create({ key: key, iv: iv, salt: salt });\n\t }\n\t };\n\n\t /**\n\t * A serializable cipher wrapper that derives the key from a password,\n\t * and returns ciphertext as a serializable cipher params object.\n\t */\n\t var PasswordBasedCipher = C_lib.PasswordBasedCipher = SerializableCipher.extend({\n\t /**\n\t * Configuration options.\n\t *\n\t * @property {KDF} kdf The key derivation function to use to generate a key and IV from a password. Default: OpenSSL\n\t */\n\t cfg: SerializableCipher.cfg.extend({\n\t kdf: OpenSSLKdf\n\t }),\n\n\t /**\n\t * Encrypts a message using a password.\n\t *\n\t * @param {Cipher} cipher The cipher algorithm to use.\n\t * @param {WordArray|string} message The message to encrypt.\n\t * @param {string} password The password.\n\t * @param {Object} cfg (Optional) The configuration options to use for this operation.\n\t *\n\t * @return {CipherParams} A cipher params object.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var ciphertextParams = CryptoJS.lib.PasswordBasedCipher.encrypt(CryptoJS.algo.AES, message, 'password');\n\t * var ciphertextParams = CryptoJS.lib.PasswordBasedCipher.encrypt(CryptoJS.algo.AES, message, 'password', { format: CryptoJS.format.OpenSSL });\n\t */\n\t encrypt: function (cipher, message, password, cfg) {\n\t // Apply config defaults\n\t cfg = this.cfg.extend(cfg);\n\n\t // Derive key and other params\n\t var derivedParams = cfg.kdf.execute(password, cipher.keySize, cipher.ivSize, cfg.salt, cfg.hasher);\n\n\t // Add IV to config\n\t cfg.iv = derivedParams.iv;\n\n\t // Encrypt\n\t var ciphertext = SerializableCipher.encrypt.call(this, cipher, message, derivedParams.key, cfg);\n\n\t // Mix in derived params\n\t ciphertext.mixIn(derivedParams);\n\n\t return ciphertext;\n\t },\n\n\t /**\n\t * Decrypts serialized ciphertext using a password.\n\t *\n\t * @param {Cipher} cipher The cipher algorithm to use.\n\t * @param {CipherParams|string} ciphertext The ciphertext to decrypt.\n\t * @param {string} password The password.\n\t * @param {Object} cfg (Optional) The configuration options to use for this operation.\n\t *\n\t * @return {WordArray} The plaintext.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var plaintext = CryptoJS.lib.PasswordBasedCipher.decrypt(CryptoJS.algo.AES, formattedCiphertext, 'password', { format: CryptoJS.format.OpenSSL });\n\t * var plaintext = CryptoJS.lib.PasswordBasedCipher.decrypt(CryptoJS.algo.AES, ciphertextParams, 'password', { format: CryptoJS.format.OpenSSL });\n\t */\n\t decrypt: function (cipher, ciphertext, password, cfg) {\n\t // Apply config defaults\n\t cfg = this.cfg.extend(cfg);\n\n\t // Convert string to CipherParams\n\t ciphertext = this._parse(ciphertext, cfg.format);\n\n\t // Derive key and other params\n\t var derivedParams = cfg.kdf.execute(password, cipher.keySize, cipher.ivSize, ciphertext.salt, cfg.hasher);\n\n\t // Add IV to config\n\t cfg.iv = derivedParams.iv;\n\n\t // Decrypt\n\t var plaintext = SerializableCipher.decrypt.call(this, cipher, ciphertext, derivedParams.key, cfg);\n\n\t return plaintext;\n\t }\n\t });\n\t}());\n\n\n}));",";(function (root, factory) {\n\tif (typeof exports === \"object\") {\n\t\t// CommonJS\n\t\tmodule.exports = exports = factory();\n\t}\n\telse if (typeof define === \"function\" && define.amd) {\n\t\t// AMD\n\t\tdefine([], factory);\n\t}\n\telse {\n\t\t// Global (browser)\n\t\troot.CryptoJS = factory();\n\t}\n}(this, function () {\n\n\t/*globals window, global, require*/\n\n\t/**\n\t * CryptoJS core components.\n\t */\n\tvar CryptoJS = CryptoJS || (function (Math, undefined) {\n\n\t var crypto;\n\n\t // Native crypto from window (Browser)\n\t if (typeof window !== 'undefined' && window.crypto) {\n\t crypto = window.crypto;\n\t }\n\n\t // Native crypto in web worker (Browser)\n\t if (typeof self !== 'undefined' && self.crypto) {\n\t crypto = self.crypto;\n\t }\n\n\t // Native crypto from worker\n\t if (typeof globalThis !== 'undefined' && globalThis.crypto) {\n\t crypto = globalThis.crypto;\n\t }\n\n\t // Native (experimental IE 11) crypto from window (Browser)\n\t if (!crypto && typeof window !== 'undefined' && window.msCrypto) {\n\t crypto = window.msCrypto;\n\t }\n\n\t // Native crypto from global (NodeJS)\n\t if (!crypto && typeof global !== 'undefined' && global.crypto) {\n\t crypto = global.crypto;\n\t }\n\n\t // Native crypto import via require (NodeJS)\n\t if (!crypto && typeof require === 'function') {\n\t try {\n\t crypto = require('crypto');\n\t } catch (err) {}\n\t }\n\n\t /*\n\t * Cryptographically secure pseudorandom number generator\n\t *\n\t * As Math.random() is cryptographically not safe to use\n\t */\n\t var cryptoSecureRandomInt = function () {\n\t if (crypto) {\n\t // Use getRandomValues method (Browser)\n\t if (typeof crypto.getRandomValues === 'function') {\n\t try {\n\t return crypto.getRandomValues(new Uint32Array(1))[0];\n\t } catch (err) {}\n\t }\n\n\t // Use randomBytes method (NodeJS)\n\t if (typeof crypto.randomBytes === 'function') {\n\t try {\n\t return crypto.randomBytes(4).readInt32LE();\n\t } catch (err) {}\n\t }\n\t }\n\n\t throw new Error('Native crypto module could not be used to get secure random number.');\n\t };\n\n\t /*\n\t * Local polyfill of Object.create\n\n\t */\n\t var create = Object.create || (function () {\n\t function F() {}\n\n\t return function (obj) {\n\t var subtype;\n\n\t F.prototype = obj;\n\n\t subtype = new F();\n\n\t F.prototype = null;\n\n\t return subtype;\n\t };\n\t }());\n\n\t /**\n\t * CryptoJS namespace.\n\t */\n\t var C = {};\n\n\t /**\n\t * Library namespace.\n\t */\n\t var C_lib = C.lib = {};\n\n\t /**\n\t * Base object for prototypal inheritance.\n\t */\n\t var Base = C_lib.Base = (function () {\n\n\n\t return {\n\t /**\n\t * Creates a new object that inherits from this object.\n\t *\n\t * @param {Object} overrides Properties to copy into the new object.\n\t *\n\t * @return {Object} The new object.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var MyType = CryptoJS.lib.Base.extend({\n\t * field: 'value',\n\t *\n\t * method: function () {\n\t * }\n\t * });\n\t */\n\t extend: function (overrides) {\n\t // Spawn\n\t var subtype = create(this);\n\n\t // Augment\n\t if (overrides) {\n\t subtype.mixIn(overrides);\n\t }\n\n\t // Create default initializer\n\t if (!subtype.hasOwnProperty('init') || this.init === subtype.init) {\n\t subtype.init = function () {\n\t subtype.$super.init.apply(this, arguments);\n\t };\n\t }\n\n\t // Initializer's prototype is the subtype object\n\t subtype.init.prototype = subtype;\n\n\t // Reference supertype\n\t subtype.$super = this;\n\n\t return subtype;\n\t },\n\n\t /**\n\t * Extends this object and runs the init method.\n\t * Arguments to create() will be passed to init().\n\t *\n\t * @return {Object} The new object.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var instance = MyType.create();\n\t */\n\t create: function () {\n\t var instance = this.extend();\n\t instance.init.apply(instance, arguments);\n\n\t return instance;\n\t },\n\n\t /**\n\t * Initializes a newly created object.\n\t * Override this method to add some logic when your objects are created.\n\t *\n\t * @example\n\t *\n\t * var MyType = CryptoJS.lib.Base.extend({\n\t * init: function () {\n\t * // ...\n\t * }\n\t * });\n\t */\n\t init: function () {\n\t },\n\n\t /**\n\t * Copies properties into this object.\n\t *\n\t * @param {Object} properties The properties to mix in.\n\t *\n\t * @example\n\t *\n\t * MyType.mixIn({\n\t * field: 'value'\n\t * });\n\t */\n\t mixIn: function (properties) {\n\t for (var propertyName in properties) {\n\t if (properties.hasOwnProperty(propertyName)) {\n\t this[propertyName] = properties[propertyName];\n\t }\n\t }\n\n\t // IE won't copy toString using the loop above\n\t if (properties.hasOwnProperty('toString')) {\n\t this.toString = properties.toString;\n\t }\n\t },\n\n\t /**\n\t * Creates a copy of this object.\n\t *\n\t * @return {Object} The clone.\n\t *\n\t * @example\n\t *\n\t * var clone = instance.clone();\n\t */\n\t clone: function () {\n\t return this.init.prototype.extend(this);\n\t }\n\t };\n\t }());\n\n\t /**\n\t * An array of 32-bit words.\n\t *\n\t * @property {Array} words The array of 32-bit words.\n\t * @property {number} sigBytes The number of significant bytes in this word array.\n\t */\n\t var WordArray = C_lib.WordArray = Base.extend({\n\t /**\n\t * Initializes a newly created word array.\n\t *\n\t * @param {Array} words (Optional) An array of 32-bit words.\n\t * @param {number} sigBytes (Optional) The number of significant bytes in the words.\n\t *\n\t * @example\n\t *\n\t * var wordArray = CryptoJS.lib.WordArray.create();\n\t * var wordArray = CryptoJS.lib.WordArray.create([0x00010203, 0x04050607]);\n\t * var wordArray = CryptoJS.lib.WordArray.create([0x00010203, 0x04050607], 6);\n\t */\n\t init: function (words, sigBytes) {\n\t words = this.words = words || [];\n\n\t if (sigBytes != undefined) {\n\t this.sigBytes = sigBytes;\n\t } else {\n\t this.sigBytes = words.length * 4;\n\t }\n\t },\n\n\t /**\n\t * Converts this word array to a string.\n\t *\n\t * @param {Encoder} encoder (Optional) The encoding strategy to use. Default: CryptoJS.enc.Hex\n\t *\n\t * @return {string} The stringified word array.\n\t *\n\t * @example\n\t *\n\t * var string = wordArray + '';\n\t * var string = wordArray.toString();\n\t * var string = wordArray.toString(CryptoJS.enc.Utf8);\n\t */\n\t toString: function (encoder) {\n\t return (encoder || Hex).stringify(this);\n\t },\n\n\t /**\n\t * Concatenates a word array to this word array.\n\t *\n\t * @param {WordArray} wordArray The word array to append.\n\t *\n\t * @return {WordArray} This word array.\n\t *\n\t * @example\n\t *\n\t * wordArray1.concat(wordArray2);\n\t */\n\t concat: function (wordArray) {\n\t // Shortcuts\n\t var thisWords = this.words;\n\t var thatWords = wordArray.words;\n\t var thisSigBytes = this.sigBytes;\n\t var thatSigBytes = wordArray.sigBytes;\n\n\t // Clamp excess bits\n\t this.clamp();\n\n\t // Concat\n\t if (thisSigBytes % 4) {\n\t // Copy one byte at a time\n\t for (var i = 0; i < thatSigBytes; i++) {\n\t var thatByte = (thatWords[i >>> 2] >>> (24 - (i % 4) * 8)) & 0xff;\n\t thisWords[(thisSigBytes + i) >>> 2] |= thatByte << (24 - ((thisSigBytes + i) % 4) * 8);\n\t }\n\t } else {\n\t // Copy one word at a time\n\t for (var j = 0; j < thatSigBytes; j += 4) {\n\t thisWords[(thisSigBytes + j) >>> 2] = thatWords[j >>> 2];\n\t }\n\t }\n\t this.sigBytes += thatSigBytes;\n\n\t // Chainable\n\t return this;\n\t },\n\n\t /**\n\t * Removes insignificant bits.\n\t *\n\t * @example\n\t *\n\t * wordArray.clamp();\n\t */\n\t clamp: function () {\n\t // Shortcuts\n\t var words = this.words;\n\t var sigBytes = this.sigBytes;\n\n\t // Clamp\n\t words[sigBytes >>> 2] &= 0xffffffff << (32 - (sigBytes % 4) * 8);\n\t words.length = Math.ceil(sigBytes / 4);\n\t },\n\n\t /**\n\t * Creates a copy of this word array.\n\t *\n\t * @return {WordArray} The clone.\n\t *\n\t * @example\n\t *\n\t * var clone = wordArray.clone();\n\t */\n\t clone: function () {\n\t var clone = Base.clone.call(this);\n\t clone.words = this.words.slice(0);\n\n\t return clone;\n\t },\n\n\t /**\n\t * Creates a word array filled with random bytes.\n\t *\n\t * @param {number} nBytes The number of random bytes to generate.\n\t *\n\t * @return {WordArray} The random word array.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var wordArray = CryptoJS.lib.WordArray.random(16);\n\t */\n\t random: function (nBytes) {\n\t var words = [];\n\n\t for (var i = 0; i < nBytes; i += 4) {\n\t words.push(cryptoSecureRandomInt());\n\t }\n\n\t return new WordArray.init(words, nBytes);\n\t }\n\t });\n\n\t /**\n\t * Encoder namespace.\n\t */\n\t var C_enc = C.enc = {};\n\n\t /**\n\t * Hex encoding strategy.\n\t */\n\t var Hex = C_enc.Hex = {\n\t /**\n\t * Converts a word array to a hex string.\n\t *\n\t * @param {WordArray} wordArray The word array.\n\t *\n\t * @return {string} The hex string.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var hexString = CryptoJS.enc.Hex.stringify(wordArray);\n\t */\n\t stringify: function (wordArray) {\n\t // Shortcuts\n\t var words = wordArray.words;\n\t var sigBytes = wordArray.sigBytes;\n\n\t // Convert\n\t var hexChars = [];\n\t for (var i = 0; i < sigBytes; i++) {\n\t var bite = (words[i >>> 2] >>> (24 - (i % 4) * 8)) & 0xff;\n\t hexChars.push((bite >>> 4).toString(16));\n\t hexChars.push((bite & 0x0f).toString(16));\n\t }\n\n\t return hexChars.join('');\n\t },\n\n\t /**\n\t * Converts a hex string to a word array.\n\t *\n\t * @param {string} hexStr The hex string.\n\t *\n\t * @return {WordArray} The word array.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var wordArray = CryptoJS.enc.Hex.parse(hexString);\n\t */\n\t parse: function (hexStr) {\n\t // Shortcut\n\t var hexStrLength = hexStr.length;\n\n\t // Convert\n\t var words = [];\n\t for (var i = 0; i < hexStrLength; i += 2) {\n\t words[i >>> 3] |= parseInt(hexStr.substr(i, 2), 16) << (24 - (i % 8) * 4);\n\t }\n\n\t return new WordArray.init(words, hexStrLength / 2);\n\t }\n\t };\n\n\t /**\n\t * Latin1 encoding strategy.\n\t */\n\t var Latin1 = C_enc.Latin1 = {\n\t /**\n\t * Converts a word array to a Latin1 string.\n\t *\n\t * @param {WordArray} wordArray The word array.\n\t *\n\t * @return {string} The Latin1 string.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var latin1String = CryptoJS.enc.Latin1.stringify(wordArray);\n\t */\n\t stringify: function (wordArray) {\n\t // Shortcuts\n\t var words = wordArray.words;\n\t var sigBytes = wordArray.sigBytes;\n\n\t // Convert\n\t var latin1Chars = [];\n\t for (var i = 0; i < sigBytes; i++) {\n\t var bite = (words[i >>> 2] >>> (24 - (i % 4) * 8)) & 0xff;\n\t latin1Chars.push(String.fromCharCode(bite));\n\t }\n\n\t return latin1Chars.join('');\n\t },\n\n\t /**\n\t * Converts a Latin1 string to a word array.\n\t *\n\t * @param {string} latin1Str The Latin1 string.\n\t *\n\t * @return {WordArray} The word array.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var wordArray = CryptoJS.enc.Latin1.parse(latin1String);\n\t */\n\t parse: function (latin1Str) {\n\t // Shortcut\n\t var latin1StrLength = latin1Str.length;\n\n\t // Convert\n\t var words = [];\n\t for (var i = 0; i < latin1StrLength; i++) {\n\t words[i >>> 2] |= (latin1Str.charCodeAt(i) & 0xff) << (24 - (i % 4) * 8);\n\t }\n\n\t return new WordArray.init(words, latin1StrLength);\n\t }\n\t };\n\n\t /**\n\t * UTF-8 encoding strategy.\n\t */\n\t var Utf8 = C_enc.Utf8 = {\n\t /**\n\t * Converts a word array to a UTF-8 string.\n\t *\n\t * @param {WordArray} wordArray The word array.\n\t *\n\t * @return {string} The UTF-8 string.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var utf8String = CryptoJS.enc.Utf8.stringify(wordArray);\n\t */\n\t stringify: function (wordArray) {\n\t try {\n\t return decodeURIComponent(escape(Latin1.stringify(wordArray)));\n\t } catch (e) {\n\t throw new Error('Malformed UTF-8 data');\n\t }\n\t },\n\n\t /**\n\t * Converts a UTF-8 string to a word array.\n\t *\n\t * @param {string} utf8Str The UTF-8 string.\n\t *\n\t * @return {WordArray} The word array.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var wordArray = CryptoJS.enc.Utf8.parse(utf8String);\n\t */\n\t parse: function (utf8Str) {\n\t return Latin1.parse(unescape(encodeURIComponent(utf8Str)));\n\t }\n\t };\n\n\t /**\n\t * Abstract buffered block algorithm template.\n\t *\n\t * The property blockSize must be implemented in a concrete subtype.\n\t *\n\t * @property {number} _minBufferSize The number of blocks that should be kept unprocessed in the buffer. Default: 0\n\t */\n\t var BufferedBlockAlgorithm = C_lib.BufferedBlockAlgorithm = Base.extend({\n\t /**\n\t * Resets this block algorithm's data buffer to its initial state.\n\t *\n\t * @example\n\t *\n\t * bufferedBlockAlgorithm.reset();\n\t */\n\t reset: function () {\n\t // Initial values\n\t this._data = new WordArray.init();\n\t this._nDataBytes = 0;\n\t },\n\n\t /**\n\t * Adds new data to this block algorithm's buffer.\n\t *\n\t * @param {WordArray|string} data The data to append. Strings are converted to a WordArray using UTF-8.\n\t *\n\t * @example\n\t *\n\t * bufferedBlockAlgorithm._append('data');\n\t * bufferedBlockAlgorithm._append(wordArray);\n\t */\n\t _append: function (data) {\n\t // Convert string to WordArray, else assume WordArray already\n\t if (typeof data == 'string') {\n\t data = Utf8.parse(data);\n\t }\n\n\t // Append\n\t this._data.concat(data);\n\t this._nDataBytes += data.sigBytes;\n\t },\n\n\t /**\n\t * Processes available data blocks.\n\t *\n\t * This method invokes _doProcessBlock(offset), which must be implemented by a concrete subtype.\n\t *\n\t * @param {boolean} doFlush Whether all blocks and partial blocks should be processed.\n\t *\n\t * @return {WordArray} The processed data.\n\t *\n\t * @example\n\t *\n\t * var processedData = bufferedBlockAlgorithm._process();\n\t * var processedData = bufferedBlockAlgorithm._process(!!'flush');\n\t */\n\t _process: function (doFlush) {\n\t var processedWords;\n\n\t // Shortcuts\n\t var data = this._data;\n\t var dataWords = data.words;\n\t var dataSigBytes = data.sigBytes;\n\t var blockSize = this.blockSize;\n\t var blockSizeBytes = blockSize * 4;\n\n\t // Count blocks ready\n\t var nBlocksReady = dataSigBytes / blockSizeBytes;\n\t if (doFlush) {\n\t // Round up to include partial blocks\n\t nBlocksReady = Math.ceil(nBlocksReady);\n\t } else {\n\t // Round down to include only full blocks,\n\t // less the number of blocks that must remain in the buffer\n\t nBlocksReady = Math.max((nBlocksReady | 0) - this._minBufferSize, 0);\n\t }\n\n\t // Count words ready\n\t var nWordsReady = nBlocksReady * blockSize;\n\n\t // Count bytes ready\n\t var nBytesReady = Math.min(nWordsReady * 4, dataSigBytes);\n\n\t // Process blocks\n\t if (nWordsReady) {\n\t for (var offset = 0; offset < nWordsReady; offset += blockSize) {\n\t // Perform concrete-algorithm logic\n\t this._doProcessBlock(dataWords, offset);\n\t }\n\n\t // Remove processed words\n\t processedWords = dataWords.splice(0, nWordsReady);\n\t data.sigBytes -= nBytesReady;\n\t }\n\n\t // Return processed words\n\t return new WordArray.init(processedWords, nBytesReady);\n\t },\n\n\t /**\n\t * Creates a copy of this object.\n\t *\n\t * @return {Object} The clone.\n\t *\n\t * @example\n\t *\n\t * var clone = bufferedBlockAlgorithm.clone();\n\t */\n\t clone: function () {\n\t var clone = Base.clone.call(this);\n\t clone._data = this._data.clone();\n\n\t return clone;\n\t },\n\n\t _minBufferSize: 0\n\t });\n\n\t /**\n\t * Abstract hasher template.\n\t *\n\t * @property {number} blockSize The number of 32-bit words this hasher operates on. Default: 16 (512 bits)\n\t */\n\t var Hasher = C_lib.Hasher = BufferedBlockAlgorithm.extend({\n\t /**\n\t * Configuration options.\n\t */\n\t cfg: Base.extend(),\n\n\t /**\n\t * Initializes a newly created hasher.\n\t *\n\t * @param {Object} cfg (Optional) The configuration options to use for this hash computation.\n\t *\n\t * @example\n\t *\n\t * var hasher = CryptoJS.algo.SHA256.create();\n\t */\n\t init: function (cfg) {\n\t // Apply config defaults\n\t this.cfg = this.cfg.extend(cfg);\n\n\t // Set initial values\n\t this.reset();\n\t },\n\n\t /**\n\t * Resets this hasher to its initial state.\n\t *\n\t * @example\n\t *\n\t * hasher.reset();\n\t */\n\t reset: function () {\n\t // Reset data buffer\n\t BufferedBlockAlgorithm.reset.call(this);\n\n\t // Perform concrete-hasher logic\n\t this._doReset();\n\t },\n\n\t /**\n\t * Updates this hasher with a message.\n\t *\n\t * @param {WordArray|string} messageUpdate The message to append.\n\t *\n\t * @return {Hasher} This hasher.\n\t *\n\t * @example\n\t *\n\t * hasher.update('message');\n\t * hasher.update(wordArray);\n\t */\n\t update: function (messageUpdate) {\n\t // Append\n\t this._append(messageUpdate);\n\n\t // Update the hash\n\t this._process();\n\n\t // Chainable\n\t return this;\n\t },\n\n\t /**\n\t * Finalizes the hash computation.\n\t * Note that the finalize operation is effectively a destructive, read-once operation.\n\t *\n\t * @param {WordArray|string} messageUpdate (Optional) A final message update.\n\t *\n\t * @return {WordArray} The hash.\n\t *\n\t * @example\n\t *\n\t * var hash = hasher.finalize();\n\t * var hash = hasher.finalize('message');\n\t * var hash = hasher.finalize(wordArray);\n\t */\n\t finalize: function (messageUpdate) {\n\t // Final message update\n\t if (messageUpdate) {\n\t this._append(messageUpdate);\n\t }\n\n\t // Perform concrete-hasher logic\n\t var hash = this._doFinalize();\n\n\t return hash;\n\t },\n\n\t blockSize: 512/32,\n\n\t /**\n\t * Creates a shortcut function to a hasher's object interface.\n\t *\n\t * @param {Hasher} hasher The hasher to create a helper for.\n\t *\n\t * @return {Function} The shortcut function.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var SHA256 = CryptoJS.lib.Hasher._createHelper(CryptoJS.algo.SHA256);\n\t */\n\t _createHelper: function (hasher) {\n\t return function (message, cfg) {\n\t return new hasher.init(cfg).finalize(message);\n\t };\n\t },\n\n\t /**\n\t * Creates a shortcut function to the HMAC's object interface.\n\t *\n\t * @param {Hasher} hasher The hasher to use in this HMAC helper.\n\t *\n\t * @return {Function} The shortcut function.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var HmacSHA256 = CryptoJS.lib.Hasher._createHmacHelper(CryptoJS.algo.SHA256);\n\t */\n\t _createHmacHelper: function (hasher) {\n\t return function (message, key) {\n\t return new C_algo.HMAC.init(hasher, key).finalize(message);\n\t };\n\t }\n\t });\n\n\t /**\n\t * Algorithm namespace.\n\t */\n\t var C_algo = C.algo = {};\n\n\t return C;\n\t}(Math));\n\n\n\treturn CryptoJS;\n\n}));",";(function (root, factory) {\n\tif (typeof exports === \"object\") {\n\t\t// CommonJS\n\t\tmodule.exports = exports = factory(require(\"./core\"));\n\t}\n\telse if (typeof define === \"function\" && define.amd) {\n\t\t// AMD\n\t\tdefine([\"./core\"], factory);\n\t}\n\telse {\n\t\t// Global (browser)\n\t\tfactory(root.CryptoJS);\n\t}\n}(this, function (CryptoJS) {\n\n\t(function () {\n\t // Shortcuts\n\t var C = CryptoJS;\n\t var C_lib = C.lib;\n\t var WordArray = C_lib.WordArray;\n\t var C_enc = C.enc;\n\n\t /**\n\t * Base64 encoding strategy.\n\t */\n\t var Base64 = C_enc.Base64 = {\n\t /**\n\t * Converts a word array to a Base64 string.\n\t *\n\t * @param {WordArray} wordArray The word array.\n\t *\n\t * @return {string} The Base64 string.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var base64String = CryptoJS.enc.Base64.stringify(wordArray);\n\t */\n\t stringify: function (wordArray) {\n\t // Shortcuts\n\t var words = wordArray.words;\n\t var sigBytes = wordArray.sigBytes;\n\t var map = this._map;\n\n\t // Clamp excess bits\n\t wordArray.clamp();\n\n\t // Convert\n\t var base64Chars = [];\n\t for (var i = 0; i < sigBytes; i += 3) {\n\t var byte1 = (words[i >>> 2] >>> (24 - (i % 4) * 8)) & 0xff;\n\t var byte2 = (words[(i + 1) >>> 2] >>> (24 - ((i + 1) % 4) * 8)) & 0xff;\n\t var byte3 = (words[(i + 2) >>> 2] >>> (24 - ((i + 2) % 4) * 8)) & 0xff;\n\n\t var triplet = (byte1 << 16) | (byte2 << 8) | byte3;\n\n\t for (var j = 0; (j < 4) && (i + j * 0.75 < sigBytes); j++) {\n\t base64Chars.push(map.charAt((triplet >>> (6 * (3 - j))) & 0x3f));\n\t }\n\t }\n\n\t // Add padding\n\t var paddingChar = map.charAt(64);\n\t if (paddingChar) {\n\t while (base64Chars.length % 4) {\n\t base64Chars.push(paddingChar);\n\t }\n\t }\n\n\t return base64Chars.join('');\n\t },\n\n\t /**\n\t * Converts a Base64 string to a word array.\n\t *\n\t * @param {string} base64Str The Base64 string.\n\t *\n\t * @return {WordArray} The word array.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var wordArray = CryptoJS.enc.Base64.parse(base64String);\n\t */\n\t parse: function (base64Str) {\n\t // Shortcuts\n\t var base64StrLength = base64Str.length;\n\t var map = this._map;\n\t var reverseMap = this._reverseMap;\n\n\t if (!reverseMap) {\n\t reverseMap = this._reverseMap = [];\n\t for (var j = 0; j < map.length; j++) {\n\t reverseMap[map.charCodeAt(j)] = j;\n\t }\n\t }\n\n\t // Ignore padding\n\t var paddingChar = map.charAt(64);\n\t if (paddingChar) {\n\t var paddingIndex = base64Str.indexOf(paddingChar);\n\t if (paddingIndex !== -1) {\n\t base64StrLength = paddingIndex;\n\t }\n\t }\n\n\t // Convert\n\t return parseLoop(base64Str, base64StrLength, reverseMap);\n\n\t },\n\n\t _map: 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/='\n\t };\n\n\t function parseLoop(base64Str, base64StrLength, reverseMap) {\n\t var words = [];\n\t var nBytes = 0;\n\t for (var i = 0; i < base64StrLength; i++) {\n\t if (i % 4) {\n\t var bits1 = reverseMap[base64Str.charCodeAt(i - 1)] << ((i % 4) * 2);\n\t var bits2 = reverseMap[base64Str.charCodeAt(i)] >>> (6 - (i % 4) * 2);\n\t var bitsCombined = bits1 | bits2;\n\t words[nBytes >>> 2] |= bitsCombined << (24 - (nBytes % 4) * 8);\n\t nBytes++;\n\t }\n\t }\n\t return WordArray.create(words, nBytes);\n\t }\n\t}());\n\n\n\treturn CryptoJS.enc.Base64;\n\n}));",";(function (root, factory) {\n\tif (typeof exports === \"object\") {\n\t\t// CommonJS\n\t\tmodule.exports = exports = factory(require(\"./core\"));\n\t}\n\telse if (typeof define === \"function\" && define.amd) {\n\t\t// AMD\n\t\tdefine([\"./core\"], factory);\n\t}\n\telse {\n\t\t// Global (browser)\n\t\tfactory(root.CryptoJS);\n\t}\n}(this, function (CryptoJS) {\n\n\t(function () {\n\t // Shortcuts\n\t var C = CryptoJS;\n\t var C_lib = C.lib;\n\t var WordArray = C_lib.WordArray;\n\t var C_enc = C.enc;\n\n\t /**\n\t * Base64url encoding strategy.\n\t */\n\t var Base64url = C_enc.Base64url = {\n\t /**\n\t * Converts a word array to a Base64url string.\n\t *\n\t * @param {WordArray} wordArray The word array.\n\t *\n\t * @param {boolean} urlSafe Whether to use url safe\n\t *\n\t * @return {string} The Base64url string.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var base64String = CryptoJS.enc.Base64url.stringify(wordArray);\n\t */\n\t stringify: function (wordArray, urlSafe) {\n\t if (urlSafe === undefined) {\n\t urlSafe = true\n\t }\n\t // Shortcuts\n\t var words = wordArray.words;\n\t var sigBytes = wordArray.sigBytes;\n\t var map = urlSafe ? this._safe_map : this._map;\n\n\t // Clamp excess bits\n\t wordArray.clamp();\n\n\t // Convert\n\t var base64Chars = [];\n\t for (var i = 0; i < sigBytes; i += 3) {\n\t var byte1 = (words[i >>> 2] >>> (24 - (i % 4) * 8)) & 0xff;\n\t var byte2 = (words[(i + 1) >>> 2] >>> (24 - ((i + 1) % 4) * 8)) & 0xff;\n\t var byte3 = (words[(i + 2) >>> 2] >>> (24 - ((i + 2) % 4) * 8)) & 0xff;\n\n\t var triplet = (byte1 << 16) | (byte2 << 8) | byte3;\n\n\t for (var j = 0; (j < 4) && (i + j * 0.75 < sigBytes); j++) {\n\t base64Chars.push(map.charAt((triplet >>> (6 * (3 - j))) & 0x3f));\n\t }\n\t }\n\n\t // Add padding\n\t var paddingChar = map.charAt(64);\n\t if (paddingChar) {\n\t while (base64Chars.length % 4) {\n\t base64Chars.push(paddingChar);\n\t }\n\t }\n\n\t return base64Chars.join('');\n\t },\n\n\t /**\n\t * Converts a Base64url string to a word array.\n\t *\n\t * @param {string} base64Str The Base64url string.\n\t *\n\t * @param {boolean} urlSafe Whether to use url safe\n\t *\n\t * @return {WordArray} The word array.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var wordArray = CryptoJS.enc.Base64url.parse(base64String);\n\t */\n\t parse: function (base64Str, urlSafe) {\n\t if (urlSafe === undefined) {\n\t urlSafe = true\n\t }\n\n\t // Shortcuts\n\t var base64StrLength = base64Str.length;\n\t var map = urlSafe ? this._safe_map : this._map;\n\t var reverseMap = this._reverseMap;\n\n\t if (!reverseMap) {\n\t reverseMap = this._reverseMap = [];\n\t for (var j = 0; j < map.length; j++) {\n\t reverseMap[map.charCodeAt(j)] = j;\n\t }\n\t }\n\n\t // Ignore padding\n\t var paddingChar = map.charAt(64);\n\t if (paddingChar) {\n\t var paddingIndex = base64Str.indexOf(paddingChar);\n\t if (paddingIndex !== -1) {\n\t base64StrLength = paddingIndex;\n\t }\n\t }\n\n\t // Convert\n\t return parseLoop(base64Str, base64StrLength, reverseMap);\n\n\t },\n\n\t _map: 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=',\n\t _safe_map: 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_',\n\t };\n\n\t function parseLoop(base64Str, base64StrLength, reverseMap) {\n\t var words = [];\n\t var nBytes = 0;\n\t for (var i = 0; i < base64StrLength; i++) {\n\t if (i % 4) {\n\t var bits1 = reverseMap[base64Str.charCodeAt(i - 1)] << ((i % 4) * 2);\n\t var bits2 = reverseMap[base64Str.charCodeAt(i)] >>> (6 - (i % 4) * 2);\n\t var bitsCombined = bits1 | bits2;\n\t words[nBytes >>> 2] |= bitsCombined << (24 - (nBytes % 4) * 8);\n\t nBytes++;\n\t }\n\t }\n\t return WordArray.create(words, nBytes);\n\t }\n\t}());\n\n\n\treturn CryptoJS.enc.Base64url;\n\n}));",";(function (root, factory) {\n\tif (typeof exports === \"object\") {\n\t\t// CommonJS\n\t\tmodule.exports = exports = factory(require(\"./core\"));\n\t}\n\telse if (typeof define === \"function\" && define.amd) {\n\t\t// AMD\n\t\tdefine([\"./core\"], factory);\n\t}\n\telse {\n\t\t// Global (browser)\n\t\tfactory(root.CryptoJS);\n\t}\n}(this, function (CryptoJS) {\n\n\t(function () {\n\t // Shortcuts\n\t var C = CryptoJS;\n\t var C_lib = C.lib;\n\t var WordArray = C_lib.WordArray;\n\t var C_enc = C.enc;\n\n\t /**\n\t * UTF-16 BE encoding strategy.\n\t */\n\t var Utf16BE = C_enc.Utf16 = C_enc.Utf16BE = {\n\t /**\n\t * Converts a word array to a UTF-16 BE string.\n\t *\n\t * @param {WordArray} wordArray The word array.\n\t *\n\t * @return {string} The UTF-16 BE string.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var utf16String = CryptoJS.enc.Utf16.stringify(wordArray);\n\t */\n\t stringify: function (wordArray) {\n\t // Shortcuts\n\t var words = wordArray.words;\n\t var sigBytes = wordArray.sigBytes;\n\n\t // Convert\n\t var utf16Chars = [];\n\t for (var i = 0; i < sigBytes; i += 2) {\n\t var codePoint = (words[i >>> 2] >>> (16 - (i % 4) * 8)) & 0xffff;\n\t utf16Chars.push(String.fromCharCode(codePoint));\n\t }\n\n\t return utf16Chars.join('');\n\t },\n\n\t /**\n\t * Converts a UTF-16 BE string to a word array.\n\t *\n\t * @param {string} utf16Str The UTF-16 BE string.\n\t *\n\t * @return {WordArray} The word array.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var wordArray = CryptoJS.enc.Utf16.parse(utf16String);\n\t */\n\t parse: function (utf16Str) {\n\t // Shortcut\n\t var utf16StrLength = utf16Str.length;\n\n\t // Convert\n\t var words = [];\n\t for (var i = 0; i < utf16StrLength; i++) {\n\t words[i >>> 1] |= utf16Str.charCodeAt(i) << (16 - (i % 2) * 16);\n\t }\n\n\t return WordArray.create(words, utf16StrLength * 2);\n\t }\n\t };\n\n\t /**\n\t * UTF-16 LE encoding strategy.\n\t */\n\t C_enc.Utf16LE = {\n\t /**\n\t * Converts a word array to a UTF-16 LE string.\n\t *\n\t * @param {WordArray} wordArray The word array.\n\t *\n\t * @return {string} The UTF-16 LE string.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var utf16Str = CryptoJS.enc.Utf16LE.stringify(wordArray);\n\t */\n\t stringify: function (wordArray) {\n\t // Shortcuts\n\t var words = wordArray.words;\n\t var sigBytes = wordArray.sigBytes;\n\n\t // Convert\n\t var utf16Chars = [];\n\t for (var i = 0; i < sigBytes; i += 2) {\n\t var codePoint = swapEndian((words[i >>> 2] >>> (16 - (i % 4) * 8)) & 0xffff);\n\t utf16Chars.push(String.fromCharCode(codePoint));\n\t }\n\n\t return utf16Chars.join('');\n\t },\n\n\t /**\n\t * Converts a UTF-16 LE string to a word array.\n\t *\n\t * @param {string} utf16Str The UTF-16 LE string.\n\t *\n\t * @return {WordArray} The word array.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var wordArray = CryptoJS.enc.Utf16LE.parse(utf16Str);\n\t */\n\t parse: function (utf16Str) {\n\t // Shortcut\n\t var utf16StrLength = utf16Str.length;\n\n\t // Convert\n\t var words = [];\n\t for (var i = 0; i < utf16StrLength; i++) {\n\t words[i >>> 1] |= swapEndian(utf16Str.charCodeAt(i) << (16 - (i % 2) * 16));\n\t }\n\n\t return WordArray.create(words, utf16StrLength * 2);\n\t }\n\t };\n\n\t function swapEndian(word) {\n\t return ((word << 8) & 0xff00ff00) | ((word >>> 8) & 0x00ff00ff);\n\t }\n\t}());\n\n\n\treturn CryptoJS.enc.Utf16;\n\n}));",";(function (root, factory, undef) {\n\tif (typeof exports === \"object\") {\n\t\t// CommonJS\n\t\tmodule.exports = exports = factory(require(\"./core\"), require(\"./sha1\"), require(\"./hmac\"));\n\t}\n\telse if (typeof define === \"function\" && define.amd) {\n\t\t// AMD\n\t\tdefine([\"./core\", \"./sha1\", \"./hmac\"], factory);\n\t}\n\telse {\n\t\t// Global (browser)\n\t\tfactory(root.CryptoJS);\n\t}\n}(this, function (CryptoJS) {\n\n\t(function () {\n\t // Shortcuts\n\t var C = CryptoJS;\n\t var C_lib = C.lib;\n\t var Base = C_lib.Base;\n\t var WordArray = C_lib.WordArray;\n\t var C_algo = C.algo;\n\t var MD5 = C_algo.MD5;\n\n\t /**\n\t * This key derivation function is meant to conform with EVP_BytesToKey.\n\t * www.openssl.org/docs/crypto/EVP_BytesToKey.html\n\t */\n\t var EvpKDF = C_algo.EvpKDF = Base.extend({\n\t /**\n\t * Configuration options.\n\t *\n\t * @property {number} keySize The key size in words to generate. Default: 4 (128 bits)\n\t * @property {Hasher} hasher The hash algorithm to use. Default: MD5\n\t * @property {number} iterations The number of iterations to perform. Default: 1\n\t */\n\t cfg: Base.extend({\n\t keySize: 128/32,\n\t hasher: MD5,\n\t iterations: 1\n\t }),\n\n\t /**\n\t * Initializes a newly created key derivation function.\n\t *\n\t * @param {Object} cfg (Optional) The configuration options to use for the derivation.\n\t *\n\t * @example\n\t *\n\t * var kdf = CryptoJS.algo.EvpKDF.create();\n\t * var kdf = CryptoJS.algo.EvpKDF.create({ keySize: 8 });\n\t * var kdf = CryptoJS.algo.EvpKDF.create({ keySize: 8, iterations: 1000 });\n\t */\n\t init: function (cfg) {\n\t this.cfg = this.cfg.extend(cfg);\n\t },\n\n\t /**\n\t * Derives a key from a password.\n\t *\n\t * @param {WordArray|string} password The password.\n\t * @param {WordArray|string} salt A salt.\n\t *\n\t * @return {WordArray} The derived key.\n\t *\n\t * @example\n\t *\n\t * var key = kdf.compute(password, salt);\n\t */\n\t compute: function (password, salt) {\n\t var block;\n\n\t // Shortcut\n\t var cfg = this.cfg;\n\n\t // Init hasher\n\t var hasher = cfg.hasher.create();\n\n\t // Initial values\n\t var derivedKey = WordArray.create();\n\n\t // Shortcuts\n\t var derivedKeyWords = derivedKey.words;\n\t var keySize = cfg.keySize;\n\t var iterations = cfg.iterations;\n\n\t // Generate key\n\t while (derivedKeyWords.length < keySize) {\n\t if (block) {\n\t hasher.update(block);\n\t }\n\t block = hasher.update(password).finalize(salt);\n\t hasher.reset();\n\n\t // Iterations\n\t for (var i = 1; i < iterations; i++) {\n\t block = hasher.finalize(block);\n\t hasher.reset();\n\t }\n\n\t derivedKey.concat(block);\n\t }\n\t derivedKey.sigBytes = keySize * 4;\n\n\t return derivedKey;\n\t }\n\t });\n\n\t /**\n\t * Derives a key from a password.\n\t *\n\t * @param {WordArray|string} password The password.\n\t * @param {WordArray|string} salt A salt.\n\t * @param {Object} cfg (Optional) The configuration options to use for this computation.\n\t *\n\t * @return {WordArray} The derived key.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var key = CryptoJS.EvpKDF(password, salt);\n\t * var key = CryptoJS.EvpKDF(password, salt, { keySize: 8 });\n\t * var key = CryptoJS.EvpKDF(password, salt, { keySize: 8, iterations: 1000 });\n\t */\n\t C.EvpKDF = function (password, salt, cfg) {\n\t return EvpKDF.create(cfg).compute(password, salt);\n\t };\n\t}());\n\n\n\treturn CryptoJS.EvpKDF;\n\n}));",";(function (root, factory, undef) {\n\tif (typeof exports === \"object\") {\n\t\t// CommonJS\n\t\tmodule.exports = exports = factory(require(\"./core\"), require(\"./cipher-core\"));\n\t}\n\telse if (typeof define === \"function\" && define.amd) {\n\t\t// AMD\n\t\tdefine([\"./core\", \"./cipher-core\"], factory);\n\t}\n\telse {\n\t\t// Global (browser)\n\t\tfactory(root.CryptoJS);\n\t}\n}(this, function (CryptoJS) {\n\n\t(function (undefined) {\n\t // Shortcuts\n\t var C = CryptoJS;\n\t var C_lib = C.lib;\n\t var CipherParams = C_lib.CipherParams;\n\t var C_enc = C.enc;\n\t var Hex = C_enc.Hex;\n\t var C_format = C.format;\n\n\t var HexFormatter = C_format.Hex = {\n\t /**\n\t * Converts the ciphertext of a cipher params object to a hexadecimally encoded string.\n\t *\n\t * @param {CipherParams} cipherParams The cipher params object.\n\t *\n\t * @return {string} The hexadecimally encoded string.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var hexString = CryptoJS.format.Hex.stringify(cipherParams);\n\t */\n\t stringify: function (cipherParams) {\n\t return cipherParams.ciphertext.toString(Hex);\n\t },\n\n\t /**\n\t * Converts a hexadecimally encoded ciphertext string to a cipher params object.\n\t *\n\t * @param {string} input The hexadecimally encoded string.\n\t *\n\t * @return {CipherParams} The cipher params object.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var cipherParams = CryptoJS.format.Hex.parse(hexString);\n\t */\n\t parse: function (input) {\n\t var ciphertext = Hex.parse(input);\n\t return CipherParams.create({ ciphertext: ciphertext });\n\t }\n\t };\n\t}());\n\n\n\treturn CryptoJS.format.Hex;\n\n}));",";(function (root, factory) {\n\tif (typeof exports === \"object\") {\n\t\t// CommonJS\n\t\tmodule.exports = exports = factory(require(\"./core\"));\n\t}\n\telse if (typeof define === \"function\" && define.amd) {\n\t\t// AMD\n\t\tdefine([\"./core\"], factory);\n\t}\n\telse {\n\t\t// Global (browser)\n\t\tfactory(root.CryptoJS);\n\t}\n}(this, function (CryptoJS) {\n\n\t(function () {\n\t // Shortcuts\n\t var C = CryptoJS;\n\t var C_lib = C.lib;\n\t var Base = C_lib.Base;\n\t var C_enc = C.enc;\n\t var Utf8 = C_enc.Utf8;\n\t var C_algo = C.algo;\n\n\t /**\n\t * HMAC algorithm.\n\t */\n\t var HMAC = C_algo.HMAC = Base.extend({\n\t /**\n\t * Initializes a newly created HMAC.\n\t *\n\t * @param {Hasher} hasher The hash algorithm to use.\n\t * @param {WordArray|string} key The secret key.\n\t *\n\t * @example\n\t *\n\t * var hmacHasher = CryptoJS.algo.HMAC.create(CryptoJS.algo.SHA256, key);\n\t */\n\t init: function (hasher, key) {\n\t // Init hasher\n\t hasher = this._hasher = new hasher.init();\n\n\t // Convert string to WordArray, else assume WordArray already\n\t if (typeof key == 'string') {\n\t key = Utf8.parse(key);\n\t }\n\n\t // Shortcuts\n\t var hasherBlockSize = hasher.blockSize;\n\t var hasherBlockSizeBytes = hasherBlockSize * 4;\n\n\t // Allow arbitrary length keys\n\t if (key.sigBytes > hasherBlockSizeBytes) {\n\t key = hasher.finalize(key);\n\t }\n\n\t // Clamp excess bits\n\t key.clamp();\n\n\t // Clone key for inner and outer pads\n\t var oKey = this._oKey = key.clone();\n\t var iKey = this._iKey = key.clone();\n\n\t // Shortcuts\n\t var oKeyWords = oKey.words;\n\t var iKeyWords = iKey.words;\n\n\t // XOR keys with pad constants\n\t for (var i = 0; i < hasherBlockSize; i++) {\n\t oKeyWords[i] ^= 0x5c5c5c5c;\n\t iKeyWords[i] ^= 0x36363636;\n\t }\n\t oKey.sigBytes = iKey.sigBytes = hasherBlockSizeBytes;\n\n\t // Set initial values\n\t this.reset();\n\t },\n\n\t /**\n\t * Resets this HMAC to its initial state.\n\t *\n\t * @example\n\t *\n\t * hmacHasher.reset();\n\t */\n\t reset: function () {\n\t // Shortcut\n\t var hasher = this._hasher;\n\n\t // Reset\n\t hasher.reset();\n\t hasher.update(this._iKey);\n\t },\n\n\t /**\n\t * Updates this HMAC with a message.\n\t *\n\t * @param {WordArray|string} messageUpdate The message to append.\n\t *\n\t * @return {HMAC} This HMAC instance.\n\t *\n\t * @example\n\t *\n\t * hmacHasher.update('message');\n\t * hmacHasher.update(wordArray);\n\t */\n\t update: function (messageUpdate) {\n\t this._hasher.update(messageUpdate);\n\n\t // Chainable\n\t return this;\n\t },\n\n\t /**\n\t * Finalizes the HMAC computation.\n\t * Note that the finalize operation is effectively a destructive, read-once operation.\n\t *\n\t * @param {WordArray|string} messageUpdate (Optional) A final message update.\n\t *\n\t * @return {WordArray} The HMAC.\n\t *\n\t * @example\n\t *\n\t * var hmac = hmacHasher.finalize();\n\t * var hmac = hmacHasher.finalize('message');\n\t * var hmac = hmacHasher.finalize(wordArray);\n\t */\n\t finalize: function (messageUpdate) {\n\t // Shortcut\n\t var hasher = this._hasher;\n\n\t // Compute HMAC\n\t var innerHash = hasher.finalize(messageUpdate);\n\t hasher.reset();\n\t var hmac = hasher.finalize(this._oKey.clone().concat(innerHash));\n\n\t return hmac;\n\t }\n\t });\n\t}());\n\n\n}));",";(function (root, factory, undef) {\n\tif (typeof exports === \"object\") {\n\t\t// CommonJS\n\t\tmodule.exports = exports = factory(require(\"./core\"), require(\"./x64-core\"), require(\"./lib-typedarrays\"), require(\"./enc-utf16\"), require(\"./enc-base64\"), require(\"./enc-base64url\"), require(\"./md5\"), require(\"./sha1\"), require(\"./sha256\"), require(\"./sha224\"), require(\"./sha512\"), require(\"./sha384\"), require(\"./sha3\"), require(\"./ripemd160\"), require(\"./hmac\"), require(\"./pbkdf2\"), require(\"./evpkdf\"), require(\"./cipher-core\"), require(\"./mode-cfb\"), require(\"./mode-ctr\"), require(\"./mode-ctr-gladman\"), require(\"./mode-ofb\"), require(\"./mode-ecb\"), require(\"./pad-ansix923\"), require(\"./pad-iso10126\"), require(\"./pad-iso97971\"), require(\"./pad-zeropadding\"), require(\"./pad-nopadding\"), require(\"./format-hex\"), require(\"./aes\"), require(\"./tripledes\"), require(\"./rc4\"), require(\"./rabbit\"), require(\"./rabbit-legacy\"), require(\"./blowfish\"));\n\t}\n\telse if (typeof define === \"function\" && define.amd) {\n\t\t// AMD\n\t\tdefine([\"./core\", \"./x64-core\", \"./lib-typedarrays\", \"./enc-utf16\", \"./enc-base64\", \"./enc-base64url\", \"./md5\", \"./sha1\", \"./sha256\", \"./sha224\", \"./sha512\", \"./sha384\", \"./sha3\", \"./ripemd160\", \"./hmac\", \"./pbkdf2\", \"./evpkdf\", \"./cipher-core\", \"./mode-cfb\", \"./mode-ctr\", \"./mode-ctr-gladman\", \"./mode-ofb\", \"./mode-ecb\", \"./pad-ansix923\", \"./pad-iso10126\", \"./pad-iso97971\", \"./pad-zeropadding\", \"./pad-nopadding\", \"./format-hex\", \"./aes\", \"./tripledes\", \"./rc4\", \"./rabbit\", \"./rabbit-legacy\", \"./blowfish\"], factory);\n\t}\n\telse {\n\t\t// Global (browser)\n\t\troot.CryptoJS = factory(root.CryptoJS);\n\t}\n}(this, function (CryptoJS) {\n\n\treturn CryptoJS;\n\n}));",";(function (root, factory) {\n\tif (typeof exports === \"object\") {\n\t\t// CommonJS\n\t\tmodule.exports = exports = factory(require(\"./core\"));\n\t}\n\telse if (typeof define === \"function\" && define.amd) {\n\t\t// AMD\n\t\tdefine([\"./core\"], factory);\n\t}\n\telse {\n\t\t// Global (browser)\n\t\tfactory(root.CryptoJS);\n\t}\n}(this, function (CryptoJS) {\n\n\t(function () {\n\t // Check if typed arrays are supported\n\t if (typeof ArrayBuffer != 'function') {\n\t return;\n\t }\n\n\t // Shortcuts\n\t var C = CryptoJS;\n\t var C_lib = C.lib;\n\t var WordArray = C_lib.WordArray;\n\n\t // Reference original init\n\t var superInit = WordArray.init;\n\n\t // Augment WordArray.init to handle typed arrays\n\t var subInit = WordArray.init = function (typedArray) {\n\t // Convert buffers to uint8\n\t if (typedArray instanceof ArrayBuffer) {\n\t typedArray = new Uint8Array(typedArray);\n\t }\n\n\t // Convert other array views to uint8\n\t if (\n\t typedArray instanceof Int8Array ||\n\t (typeof Uint8ClampedArray !== \"undefined\" && typedArray instanceof Uint8ClampedArray) ||\n\t typedArray instanceof Int16Array ||\n\t typedArray instanceof Uint16Array ||\n\t typedArray instanceof Int32Array ||\n\t typedArray instanceof Uint32Array ||\n\t typedArray instanceof Float32Array ||\n\t typedArray instanceof Float64Array\n\t ) {\n\t typedArray = new Uint8Array(typedArray.buffer, typedArray.byteOffset, typedArray.byteLength);\n\t }\n\n\t // Handle Uint8Array\n\t if (typedArray instanceof Uint8Array) {\n\t // Shortcut\n\t var typedArrayByteLength = typedArray.byteLength;\n\n\t // Extract bytes\n\t var words = [];\n\t for (var i = 0; i < typedArrayByteLength; i++) {\n\t words[i >>> 2] |= typedArray[i] << (24 - (i % 4) * 8);\n\t }\n\n\t // Initialize this word array\n\t superInit.call(this, words, typedArrayByteLength);\n\t } else {\n\t // Else call normal init\n\t superInit.apply(this, arguments);\n\t }\n\t };\n\n\t subInit.prototype = WordArray;\n\t}());\n\n\n\treturn CryptoJS.lib.WordArray;\n\n}));",";(function (root, factory) {\n\tif (typeof exports === \"object\") {\n\t\t// CommonJS\n\t\tmodule.exports = exports = factory(require(\"./core\"));\n\t}\n\telse if (typeof define === \"function\" && define.amd) {\n\t\t// AMD\n\t\tdefine([\"./core\"], factory);\n\t}\n\telse {\n\t\t// Global (browser)\n\t\tfactory(root.CryptoJS);\n\t}\n}(this, function (CryptoJS) {\n\n\t(function (Math) {\n\t // Shortcuts\n\t var C = CryptoJS;\n\t var C_lib = C.lib;\n\t var WordArray = C_lib.WordArray;\n\t var Hasher = C_lib.Hasher;\n\t var C_algo = C.algo;\n\n\t // Constants table\n\t var T = [];\n\n\t // Compute constants\n\t (function () {\n\t for (var i = 0; i < 64; i++) {\n\t T[i] = (Math.abs(Math.sin(i + 1)) * 0x100000000) | 0;\n\t }\n\t }());\n\n\t /**\n\t * MD5 hash algorithm.\n\t */\n\t var MD5 = C_algo.MD5 = Hasher.extend({\n\t _doReset: function () {\n\t this._hash = new WordArray.init([\n\t 0x67452301, 0xefcdab89,\n\t 0x98badcfe, 0x10325476\n\t ]);\n\t },\n\n\t _doProcessBlock: function (M, offset) {\n\t // Swap endian\n\t for (var i = 0; i < 16; i++) {\n\t // Shortcuts\n\t var offset_i = offset + i;\n\t var M_offset_i = M[offset_i];\n\n\t M[offset_i] = (\n\t (((M_offset_i << 8) | (M_offset_i >>> 24)) & 0x00ff00ff) |\n\t (((M_offset_i << 24) | (M_offset_i >>> 8)) & 0xff00ff00)\n\t );\n\t }\n\n\t // Shortcuts\n\t var H = this._hash.words;\n\n\t var M_offset_0 = M[offset + 0];\n\t var M_offset_1 = M[offset + 1];\n\t var M_offset_2 = M[offset + 2];\n\t var M_offset_3 = M[offset + 3];\n\t var M_offset_4 = M[offset + 4];\n\t var M_offset_5 = M[offset + 5];\n\t var M_offset_6 = M[offset + 6];\n\t var M_offset_7 = M[offset + 7];\n\t var M_offset_8 = M[offset + 8];\n\t var M_offset_9 = M[offset + 9];\n\t var M_offset_10 = M[offset + 10];\n\t var M_offset_11 = M[offset + 11];\n\t var M_offset_12 = M[offset + 12];\n\t var M_offset_13 = M[offset + 13];\n\t var M_offset_14 = M[offset + 14];\n\t var M_offset_15 = M[offset + 15];\n\n\t // Working variables\n\t var a = H[0];\n\t var b = H[1];\n\t var c = H[2];\n\t var d = H[3];\n\n\t // Computation\n\t a = FF(a, b, c, d, M_offset_0, 7, T[0]);\n\t d = FF(d, a, b, c, M_offset_1, 12, T[1]);\n\t c = FF(c, d, a, b, M_offset_2, 17, T[2]);\n\t b = FF(b, c, d, a, M_offset_3, 22, T[3]);\n\t a = FF(a, b, c, d, M_offset_4, 7, T[4]);\n\t d = FF(d, a, b, c, M_offset_5, 12, T[5]);\n\t c = FF(c, d, a, b, M_offset_6, 17, T[6]);\n\t b = FF(b, c, d, a, M_offset_7, 22, T[7]);\n\t a = FF(a, b, c, d, M_offset_8, 7, T[8]);\n\t d = FF(d, a, b, c, M_offset_9, 12, T[9]);\n\t c = FF(c, d, a, b, M_offset_10, 17, T[10]);\n\t b = FF(b, c, d, a, M_offset_11, 22, T[11]);\n\t a = FF(a, b, c, d, M_offset_12, 7, T[12]);\n\t d = FF(d, a, b, c, M_offset_13, 12, T[13]);\n\t c = FF(c, d, a, b, M_offset_14, 17, T[14]);\n\t b = FF(b, c, d, a, M_offset_15, 22, T[15]);\n\n\t a = GG(a, b, c, d, M_offset_1, 5, T[16]);\n\t d = GG(d, a, b, c, M_offset_6, 9, T[17]);\n\t c = GG(c, d, a, b, M_offset_11, 14, T[18]);\n\t b = GG(b, c, d, a, M_offset_0, 20, T[19]);\n\t a = GG(a, b, c, d, M_offset_5, 5, T[20]);\n\t d = GG(d, a, b, c, M_offset_10, 9, T[21]);\n\t c = GG(c, d, a, b, M_offset_15, 14, T[22]);\n\t b = GG(b, c, d, a, M_offset_4, 20, T[23]);\n\t a = GG(a, b, c, d, M_offset_9, 5, T[24]);\n\t d = GG(d, a, b, c, M_offset_14, 9, T[25]);\n\t c = GG(c, d, a, b, M_offset_3, 14, T[26]);\n\t b = GG(b, c, d, a, M_offset_8, 20, T[27]);\n\t a = GG(a, b, c, d, M_offset_13, 5, T[28]);\n\t d = GG(d, a, b, c, M_offset_2, 9, T[29]);\n\t c = GG(c, d, a, b, M_offset_7, 14, T[30]);\n\t b = GG(b, c, d, a, M_offset_12, 20, T[31]);\n\n\t a = HH(a, b, c, d, M_offset_5, 4, T[32]);\n\t d = HH(d, a, b, c, M_offset_8, 11, T[33]);\n\t c = HH(c, d, a, b, M_offset_11, 16, T[34]);\n\t b = HH(b, c, d, a, M_offset_14, 23, T[35]);\n\t a = HH(a, b, c, d, M_offset_1, 4, T[36]);\n\t d = HH(d, a, b, c, M_offset_4, 11, T[37]);\n\t c = HH(c, d, a, b, M_offset_7, 16, T[38]);\n\t b = HH(b, c, d, a, M_offset_10, 23, T[39]);\n\t a = HH(a, b, c, d, M_offset_13, 4, T[40]);\n\t d = HH(d, a, b, c, M_offset_0, 11, T[41]);\n\t c = HH(c, d, a, b, M_offset_3, 16, T[42]);\n\t b = HH(b, c, d, a, M_offset_6, 23, T[43]);\n\t a = HH(a, b, c, d, M_offset_9, 4, T[44]);\n\t d = HH(d, a, b, c, M_offset_12, 11, T[45]);\n\t c = HH(c, d, a, b, M_offset_15, 16, T[46]);\n\t b = HH(b, c, d, a, M_offset_2, 23, T[47]);\n\n\t a = II(a, b, c, d, M_offset_0, 6, T[48]);\n\t d = II(d, a, b, c, M_offset_7, 10, T[49]);\n\t c = II(c, d, a, b, M_offset_14, 15, T[50]);\n\t b = II(b, c, d, a, M_offset_5, 21, T[51]);\n\t a = II(a, b, c, d, M_offset_12, 6, T[52]);\n\t d = II(d, a, b, c, M_offset_3, 10, T[53]);\n\t c = II(c, d, a, b, M_offset_10, 15, T[54]);\n\t b = II(b, c, d, a, M_offset_1, 21, T[55]);\n\t a = II(a, b, c, d, M_offset_8, 6, T[56]);\n\t d = II(d, a, b, c, M_offset_15, 10, T[57]);\n\t c = II(c, d, a, b, M_offset_6, 15, T[58]);\n\t b = II(b, c, d, a, M_offset_13, 21, T[59]);\n\t a = II(a, b, c, d, M_offset_4, 6, T[60]);\n\t d = II(d, a, b, c, M_offset_11, 10, T[61]);\n\t c = II(c, d, a, b, M_offset_2, 15, T[62]);\n\t b = II(b, c, d, a, M_offset_9, 21, T[63]);\n\n\t // Intermediate hash value\n\t H[0] = (H[0] + a) | 0;\n\t H[1] = (H[1] + b) | 0;\n\t H[2] = (H[2] + c) | 0;\n\t H[3] = (H[3] + d) | 0;\n\t },\n\n\t _doFinalize: function () {\n\t // Shortcuts\n\t var data = this._data;\n\t var dataWords = data.words;\n\n\t var nBitsTotal = this._nDataBytes * 8;\n\t var nBitsLeft = data.sigBytes * 8;\n\n\t // Add padding\n\t dataWords[nBitsLeft >>> 5] |= 0x80 << (24 - nBitsLeft % 32);\n\n\t var nBitsTotalH = Math.floor(nBitsTotal / 0x100000000);\n\t var nBitsTotalL = nBitsTotal;\n\t dataWords[(((nBitsLeft + 64) >>> 9) << 4) + 15] = (\n\t (((nBitsTotalH << 8) | (nBitsTotalH >>> 24)) & 0x00ff00ff) |\n\t (((nBitsTotalH << 24) | (nBitsTotalH >>> 8)) & 0xff00ff00)\n\t );\n\t dataWords[(((nBitsLeft + 64) >>> 9) << 4) + 14] = (\n\t (((nBitsTotalL << 8) | (nBitsTotalL >>> 24)) & 0x00ff00ff) |\n\t (((nBitsTotalL << 24) | (nBitsTotalL >>> 8)) & 0xff00ff00)\n\t );\n\n\t data.sigBytes = (dataWords.length + 1) * 4;\n\n\t // Hash final blocks\n\t this._process();\n\n\t // Shortcuts\n\t var hash = this._hash;\n\t var H = hash.words;\n\n\t // Swap endian\n\t for (var i = 0; i < 4; i++) {\n\t // Shortcut\n\t var H_i = H[i];\n\n\t H[i] = (((H_i << 8) | (H_i >>> 24)) & 0x00ff00ff) |\n\t (((H_i << 24) | (H_i >>> 8)) & 0xff00ff00);\n\t }\n\n\t // Return final computed hash\n\t return hash;\n\t },\n\n\t clone: function () {\n\t var clone = Hasher.clone.call(this);\n\t clone._hash = this._hash.clone();\n\n\t return clone;\n\t }\n\t });\n\n\t function FF(a, b, c, d, x, s, t) {\n\t var n = a + ((b & c) | (~b & d)) + x + t;\n\t return ((n << s) | (n >>> (32 - s))) + b;\n\t }\n\n\t function GG(a, b, c, d, x, s, t) {\n\t var n = a + ((b & d) | (c & ~d)) + x + t;\n\t return ((n << s) | (n >>> (32 - s))) + b;\n\t }\n\n\t function HH(a, b, c, d, x, s, t) {\n\t var n = a + (b ^ c ^ d) + x + t;\n\t return ((n << s) | (n >>> (32 - s))) + b;\n\t }\n\n\t function II(a, b, c, d, x, s, t) {\n\t var n = a + (c ^ (b | ~d)) + x + t;\n\t return ((n << s) | (n >>> (32 - s))) + b;\n\t }\n\n\t /**\n\t * Shortcut function to the hasher's object interface.\n\t *\n\t * @param {WordArray|string} message The message to hash.\n\t *\n\t * @return {WordArray} The hash.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var hash = CryptoJS.MD5('message');\n\t * var hash = CryptoJS.MD5(wordArray);\n\t */\n\t C.MD5 = Hasher._createHelper(MD5);\n\n\t /**\n\t * Shortcut function to the HMAC's object interface.\n\t *\n\t * @param {WordArray|string} message The message to hash.\n\t * @param {WordArray|string} key The secret key.\n\t *\n\t * @return {WordArray} The HMAC.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var hmac = CryptoJS.HmacMD5(message, key);\n\t */\n\t C.HmacMD5 = Hasher._createHmacHelper(MD5);\n\t}(Math));\n\n\n\treturn CryptoJS.MD5;\n\n}));",";(function (root, factory, undef) {\n\tif (typeof exports === \"object\") {\n\t\t// CommonJS\n\t\tmodule.exports = exports = factory(require(\"./core\"), require(\"./cipher-core\"));\n\t}\n\telse if (typeof define === \"function\" && define.amd) {\n\t\t// AMD\n\t\tdefine([\"./core\", \"./cipher-core\"], factory);\n\t}\n\telse {\n\t\t// Global (browser)\n\t\tfactory(root.CryptoJS);\n\t}\n}(this, function (CryptoJS) {\n\n\t/**\n\t * Cipher Feedback block mode.\n\t */\n\tCryptoJS.mode.CFB = (function () {\n\t var CFB = CryptoJS.lib.BlockCipherMode.extend();\n\n\t CFB.Encryptor = CFB.extend({\n\t processBlock: function (words, offset) {\n\t // Shortcuts\n\t var cipher = this._cipher;\n\t var blockSize = cipher.blockSize;\n\n\t generateKeystreamAndEncrypt.call(this, words, offset, blockSize, cipher);\n\n\t // Remember this block to use with next block\n\t this._prevBlock = words.slice(offset, offset + blockSize);\n\t }\n\t });\n\n\t CFB.Decryptor = CFB.extend({\n\t processBlock: function (words, offset) {\n\t // Shortcuts\n\t var cipher = this._cipher;\n\t var blockSize = cipher.blockSize;\n\n\t // Remember this block to use with next block\n\t var thisBlock = words.slice(offset, offset + blockSize);\n\n\t generateKeystreamAndEncrypt.call(this, words, offset, blockSize, cipher);\n\n\t // This block becomes the previous block\n\t this._prevBlock = thisBlock;\n\t }\n\t });\n\n\t function generateKeystreamAndEncrypt(words, offset, blockSize, cipher) {\n\t var keystream;\n\n\t // Shortcut\n\t var iv = this._iv;\n\n\t // Generate keystream\n\t if (iv) {\n\t keystream = iv.slice(0);\n\n\t // Remove IV for subsequent blocks\n\t this._iv = undefined;\n\t } else {\n\t keystream = this._prevBlock;\n\t }\n\t cipher.encryptBlock(keystream, 0);\n\n\t // Encrypt\n\t for (var i = 0; i < blockSize; i++) {\n\t words[offset + i] ^= keystream[i];\n\t }\n\t }\n\n\t return CFB;\n\t}());\n\n\n\treturn CryptoJS.mode.CFB;\n\n}));",";(function (root, factory, undef) {\n\tif (typeof exports === \"object\") {\n\t\t// CommonJS\n\t\tmodule.exports = exports = factory(require(\"./core\"), require(\"./cipher-core\"));\n\t}\n\telse if (typeof define === \"function\" && define.amd) {\n\t\t// AMD\n\t\tdefine([\"./core\", \"./cipher-core\"], factory);\n\t}\n\telse {\n\t\t// Global (browser)\n\t\tfactory(root.CryptoJS);\n\t}\n}(this, function (CryptoJS) {\n\n\t/** @preserve\n\t * Counter block mode compatible with Dr Brian Gladman fileenc.c\n\t * derived from CryptoJS.mode.CTR\n\t * Jan Hruby jhruby.web@gmail.com\n\t */\n\tCryptoJS.mode.CTRGladman = (function () {\n\t var CTRGladman = CryptoJS.lib.BlockCipherMode.extend();\n\n\t\tfunction incWord(word)\n\t\t{\n\t\t\tif (((word >> 24) & 0xff) === 0xff) { //overflow\n\t\t\tvar b1 = (word >> 16)&0xff;\n\t\t\tvar b2 = (word >> 8)&0xff;\n\t\t\tvar b3 = word & 0xff;\n\n\t\t\tif (b1 === 0xff) // overflow b1\n\t\t\t{\n\t\t\tb1 = 0;\n\t\t\tif (b2 === 0xff)\n\t\t\t{\n\t\t\t\tb2 = 0;\n\t\t\t\tif (b3 === 0xff)\n\t\t\t\t{\n\t\t\t\t\tb3 = 0;\n\t\t\t\t}\n\t\t\t\telse\n\t\t\t\t{\n\t\t\t\t\t++b3;\n\t\t\t\t}\n\t\t\t}\n\t\t\telse\n\t\t\t{\n\t\t\t\t++b2;\n\t\t\t}\n\t\t\t}\n\t\t\telse\n\t\t\t{\n\t\t\t++b1;\n\t\t\t}\n\n\t\t\tword = 0;\n\t\t\tword += (b1 << 16);\n\t\t\tword += (b2 << 8);\n\t\t\tword += b3;\n\t\t\t}\n\t\t\telse\n\t\t\t{\n\t\t\tword += (0x01 << 24);\n\t\t\t}\n\t\t\treturn word;\n\t\t}\n\n\t\tfunction incCounter(counter)\n\t\t{\n\t\t\tif ((counter[0] = incWord(counter[0])) === 0)\n\t\t\t{\n\t\t\t\t// encr_data in fileenc.c from Dr Brian Gladman's counts only with DWORD j < 8\n\t\t\t\tcounter[1] = incWord(counter[1]);\n\t\t\t}\n\t\t\treturn counter;\n\t\t}\n\n\t var Encryptor = CTRGladman.Encryptor = CTRGladman.extend({\n\t processBlock: function (words, offset) {\n\t // Shortcuts\n\t var cipher = this._cipher\n\t var blockSize = cipher.blockSize;\n\t var iv = this._iv;\n\t var counter = this._counter;\n\n\t // Generate keystream\n\t if (iv) {\n\t counter = this._counter = iv.slice(0);\n\n\t // Remove IV for subsequent blocks\n\t this._iv = undefined;\n\t }\n\n\t\t\t\tincCounter(counter);\n\n\t\t\t\tvar keystream = counter.slice(0);\n\t cipher.encryptBlock(keystream, 0);\n\n\t // Encrypt\n\t for (var i = 0; i < blockSize; i++) {\n\t words[offset + i] ^= keystream[i];\n\t }\n\t }\n\t });\n\n\t CTRGladman.Decryptor = Encryptor;\n\n\t return CTRGladman;\n\t}());\n\n\n\n\n\treturn CryptoJS.mode.CTRGladman;\n\n}));",";(function (root, factory, undef) {\n\tif (typeof exports === \"object\") {\n\t\t// CommonJS\n\t\tmodule.exports = exports = factory(require(\"./core\"), require(\"./cipher-core\"));\n\t}\n\telse if (typeof define === \"function\" && define.amd) {\n\t\t// AMD\n\t\tdefine([\"./core\", \"./cipher-core\"], factory);\n\t}\n\telse {\n\t\t// Global (browser)\n\t\tfactory(root.CryptoJS);\n\t}\n}(this, function (CryptoJS) {\n\n\t/**\n\t * Counter block mode.\n\t */\n\tCryptoJS.mode.CTR = (function () {\n\t var CTR = CryptoJS.lib.BlockCipherMode.extend();\n\n\t var Encryptor = CTR.Encryptor = CTR.extend({\n\t processBlock: function (words, offset) {\n\t // Shortcuts\n\t var cipher = this._cipher\n\t var blockSize = cipher.blockSize;\n\t var iv = this._iv;\n\t var counter = this._counter;\n\n\t // Generate keystream\n\t if (iv) {\n\t counter = this._counter = iv.slice(0);\n\n\t // Remove IV for subsequent blocks\n\t this._iv = undefined;\n\t }\n\t var keystream = counter.slice(0);\n\t cipher.encryptBlock(keystream, 0);\n\n\t // Increment counter\n\t counter[blockSize - 1] = (counter[blockSize - 1] + 1) | 0\n\n\t // Encrypt\n\t for (var i = 0; i < blockSize; i++) {\n\t words[offset + i] ^= keystream[i];\n\t }\n\t }\n\t });\n\n\t CTR.Decryptor = Encryptor;\n\n\t return CTR;\n\t}());\n\n\n\treturn CryptoJS.mode.CTR;\n\n}));",";(function (root, factory, undef) {\n\tif (typeof exports === \"object\") {\n\t\t// CommonJS\n\t\tmodule.exports = exports = factory(require(\"./core\"), require(\"./cipher-core\"));\n\t}\n\telse if (typeof define === \"function\" && define.amd) {\n\t\t// AMD\n\t\tdefine([\"./core\", \"./cipher-core\"], factory);\n\t}\n\telse {\n\t\t// Global (browser)\n\t\tfactory(root.CryptoJS);\n\t}\n}(this, function (CryptoJS) {\n\n\t/**\n\t * Electronic Codebook block mode.\n\t */\n\tCryptoJS.mode.ECB = (function () {\n\t var ECB = CryptoJS.lib.BlockCipherMode.extend();\n\n\t ECB.Encryptor = ECB.extend({\n\t processBlock: function (words, offset) {\n\t this._cipher.encryptBlock(words, offset);\n\t }\n\t });\n\n\t ECB.Decryptor = ECB.extend({\n\t processBlock: function (words, offset) {\n\t this._cipher.decryptBlock(words, offset);\n\t }\n\t });\n\n\t return ECB;\n\t}());\n\n\n\treturn CryptoJS.mode.ECB;\n\n}));",";(function (root, factory, undef) {\n\tif (typeof exports === \"object\") {\n\t\t// CommonJS\n\t\tmodule.exports = exports = factory(require(\"./core\"), require(\"./cipher-core\"));\n\t}\n\telse if (typeof define === \"function\" && define.amd) {\n\t\t// AMD\n\t\tdefine([\"./core\", \"./cipher-core\"], factory);\n\t}\n\telse {\n\t\t// Global (browser)\n\t\tfactory(root.CryptoJS);\n\t}\n}(this, function (CryptoJS) {\n\n\t/**\n\t * Output Feedback block mode.\n\t */\n\tCryptoJS.mode.OFB = (function () {\n\t var OFB = CryptoJS.lib.BlockCipherMode.extend();\n\n\t var Encryptor = OFB.Encryptor = OFB.extend({\n\t processBlock: function (words, offset) {\n\t // Shortcuts\n\t var cipher = this._cipher\n\t var blockSize = cipher.blockSize;\n\t var iv = this._iv;\n\t var keystream = this._keystream;\n\n\t // Generate keystream\n\t if (iv) {\n\t keystream = this._keystream = iv.slice(0);\n\n\t // Remove IV for subsequent blocks\n\t this._iv = undefined;\n\t }\n\t cipher.encryptBlock(keystream, 0);\n\n\t // Encrypt\n\t for (var i = 0; i < blockSize; i++) {\n\t words[offset + i] ^= keystream[i];\n\t }\n\t }\n\t });\n\n\t OFB.Decryptor = Encryptor;\n\n\t return OFB;\n\t}());\n\n\n\treturn CryptoJS.mode.OFB;\n\n}));",";(function (root, factory, undef) {\n\tif (typeof exports === \"object\") {\n\t\t// CommonJS\n\t\tmodule.exports = exports = factory(require(\"./core\"), require(\"./cipher-core\"));\n\t}\n\telse if (typeof define === \"function\" && define.amd) {\n\t\t// AMD\n\t\tdefine([\"./core\", \"./cipher-core\"], factory);\n\t}\n\telse {\n\t\t// Global (browser)\n\t\tfactory(root.CryptoJS);\n\t}\n}(this, function (CryptoJS) {\n\n\t/**\n\t * ANSI X.923 padding strategy.\n\t */\n\tCryptoJS.pad.AnsiX923 = {\n\t pad: function (data, blockSize) {\n\t // Shortcuts\n\t var dataSigBytes = data.sigBytes;\n\t var blockSizeBytes = blockSize * 4;\n\n\t // Count padding bytes\n\t var nPaddingBytes = blockSizeBytes - dataSigBytes % blockSizeBytes;\n\n\t // Compute last byte position\n\t var lastBytePos = dataSigBytes + nPaddingBytes - 1;\n\n\t // Pad\n\t data.clamp();\n\t data.words[lastBytePos >>> 2] |= nPaddingBytes << (24 - (lastBytePos % 4) * 8);\n\t data.sigBytes += nPaddingBytes;\n\t },\n\n\t unpad: function (data) {\n\t // Get number of padding bytes from last byte\n\t var nPaddingBytes = data.words[(data.sigBytes - 1) >>> 2] & 0xff;\n\n\t // Remove padding\n\t data.sigBytes -= nPaddingBytes;\n\t }\n\t};\n\n\n\treturn CryptoJS.pad.Ansix923;\n\n}));",";(function (root, factory, undef) {\n\tif (typeof exports === \"object\") {\n\t\t// CommonJS\n\t\tmodule.exports = exports = factory(require(\"./core\"), require(\"./cipher-core\"));\n\t}\n\telse if (typeof define === \"function\" && define.amd) {\n\t\t// AMD\n\t\tdefine([\"./core\", \"./cipher-core\"], factory);\n\t}\n\telse {\n\t\t// Global (browser)\n\t\tfactory(root.CryptoJS);\n\t}\n}(this, function (CryptoJS) {\n\n\t/**\n\t * ISO 10126 padding strategy.\n\t */\n\tCryptoJS.pad.Iso10126 = {\n\t pad: function (data, blockSize) {\n\t // Shortcut\n\t var blockSizeBytes = blockSize * 4;\n\n\t // Count padding bytes\n\t var nPaddingBytes = blockSizeBytes - data.sigBytes % blockSizeBytes;\n\n\t // Pad\n\t data.concat(CryptoJS.lib.WordArray.random(nPaddingBytes - 1)).\n\t concat(CryptoJS.lib.WordArray.create([nPaddingBytes << 24], 1));\n\t },\n\n\t unpad: function (data) {\n\t // Get number of padding bytes from last byte\n\t var nPaddingBytes = data.words[(data.sigBytes - 1) >>> 2] & 0xff;\n\n\t // Remove padding\n\t data.sigBytes -= nPaddingBytes;\n\t }\n\t};\n\n\n\treturn CryptoJS.pad.Iso10126;\n\n}));",";(function (root, factory, undef) {\n\tif (typeof exports === \"object\") {\n\t\t// CommonJS\n\t\tmodule.exports = exports = factory(require(\"./core\"), require(\"./cipher-core\"));\n\t}\n\telse if (typeof define === \"function\" && define.amd) {\n\t\t// AMD\n\t\tdefine([\"./core\", \"./cipher-core\"], factory);\n\t}\n\telse {\n\t\t// Global (browser)\n\t\tfactory(root.CryptoJS);\n\t}\n}(this, function (CryptoJS) {\n\n\t/**\n\t * ISO/IEC 9797-1 Padding Method 2.\n\t */\n\tCryptoJS.pad.Iso97971 = {\n\t pad: function (data, blockSize) {\n\t // Add 0x80 byte\n\t data.concat(CryptoJS.lib.WordArray.create([0x80000000], 1));\n\n\t // Zero pad the rest\n\t CryptoJS.pad.ZeroPadding.pad(data, blockSize);\n\t },\n\n\t unpad: function (data) {\n\t // Remove zero padding\n\t CryptoJS.pad.ZeroPadding.unpad(data);\n\n\t // Remove one more byte -- the 0x80 byte\n\t data.sigBytes--;\n\t }\n\t};\n\n\n\treturn CryptoJS.pad.Iso97971;\n\n}));",";(function (root, factory, undef) {\n\tif (typeof exports === \"object\") {\n\t\t// CommonJS\n\t\tmodule.exports = exports = factory(require(\"./core\"), require(\"./cipher-core\"));\n\t}\n\telse if (typeof define === \"function\" && define.amd) {\n\t\t// AMD\n\t\tdefine([\"./core\", \"./cipher-core\"], factory);\n\t}\n\telse {\n\t\t// Global (browser)\n\t\tfactory(root.CryptoJS);\n\t}\n}(this, function (CryptoJS) {\n\n\t/**\n\t * A noop padding strategy.\n\t */\n\tCryptoJS.pad.NoPadding = {\n\t pad: function () {\n\t },\n\n\t unpad: function () {\n\t }\n\t};\n\n\n\treturn CryptoJS.pad.NoPadding;\n\n}));",";(function (root, factory, undef) {\n\tif (typeof exports === \"object\") {\n\t\t// CommonJS\n\t\tmodule.exports = exports = factory(require(\"./core\"), require(\"./cipher-core\"));\n\t}\n\telse if (typeof define === \"function\" && define.amd) {\n\t\t// AMD\n\t\tdefine([\"./core\", \"./cipher-core\"], factory);\n\t}\n\telse {\n\t\t// Global (browser)\n\t\tfactory(root.CryptoJS);\n\t}\n}(this, function (CryptoJS) {\n\n\t/**\n\t * Zero padding strategy.\n\t */\n\tCryptoJS.pad.ZeroPadding = {\n\t pad: function (data, blockSize) {\n\t // Shortcut\n\t var blockSizeBytes = blockSize * 4;\n\n\t // Pad\n\t data.clamp();\n\t data.sigBytes += blockSizeBytes - ((data.sigBytes % blockSizeBytes) || blockSizeBytes);\n\t },\n\n\t unpad: function (data) {\n\t // Shortcut\n\t var dataWords = data.words;\n\n\t // Unpad\n\t var i = data.sigBytes - 1;\n\t for (var i = data.sigBytes - 1; i >= 0; i--) {\n\t if (((dataWords[i >>> 2] >>> (24 - (i % 4) * 8)) & 0xff)) {\n\t data.sigBytes = i + 1;\n\t break;\n\t }\n\t }\n\t }\n\t};\n\n\n\treturn CryptoJS.pad.ZeroPadding;\n\n}));",";(function (root, factory, undef) {\n\tif (typeof exports === \"object\") {\n\t\t// CommonJS\n\t\tmodule.exports = exports = factory(require(\"./core\"), require(\"./sha256\"), require(\"./hmac\"));\n\t}\n\telse if (typeof define === \"function\" && define.amd) {\n\t\t// AMD\n\t\tdefine([\"./core\", \"./sha256\", \"./hmac\"], factory);\n\t}\n\telse {\n\t\t// Global (browser)\n\t\tfactory(root.CryptoJS);\n\t}\n}(this, function (CryptoJS) {\n\n\t(function () {\n\t // Shortcuts\n\t var C = CryptoJS;\n\t var C_lib = C.lib;\n\t var Base = C_lib.Base;\n\t var WordArray = C_lib.WordArray;\n\t var C_algo = C.algo;\n\t var SHA256 = C_algo.SHA256;\n\t var HMAC = C_algo.HMAC;\n\n\t /**\n\t * Password-Based Key Derivation Function 2 algorithm.\n\t */\n\t var PBKDF2 = C_algo.PBKDF2 = Base.extend({\n\t /**\n\t * Configuration options.\n\t *\n\t * @property {number} keySize The key size in words to generate. Default: 4 (128 bits)\n\t * @property {Hasher} hasher The hasher to use. Default: SHA256\n\t * @property {number} iterations The number of iterations to perform. Default: 250000\n\t */\n\t cfg: Base.extend({\n\t keySize: 128/32,\n\t hasher: SHA256,\n\t iterations: 250000\n\t }),\n\n\t /**\n\t * Initializes a newly created key derivation function.\n\t *\n\t * @param {Object} cfg (Optional) The configuration options to use for the derivation.\n\t *\n\t * @example\n\t *\n\t * var kdf = CryptoJS.algo.PBKDF2.create();\n\t * var kdf = CryptoJS.algo.PBKDF2.create({ keySize: 8 });\n\t * var kdf = CryptoJS.algo.PBKDF2.create({ keySize: 8, iterations: 1000 });\n\t */\n\t init: function (cfg) {\n\t this.cfg = this.cfg.extend(cfg);\n\t },\n\n\t /**\n\t * Computes the Password-Based Key Derivation Function 2.\n\t *\n\t * @param {WordArray|string} password The password.\n\t * @param {WordArray|string} salt A salt.\n\t *\n\t * @return {WordArray} The derived key.\n\t *\n\t * @example\n\t *\n\t * var key = kdf.compute(password, salt);\n\t */\n\t compute: function (password, salt) {\n\t // Shortcut\n\t var cfg = this.cfg;\n\n\t // Init HMAC\n\t var hmac = HMAC.create(cfg.hasher, password);\n\n\t // Initial values\n\t var derivedKey = WordArray.create();\n\t var blockIndex = WordArray.create([0x00000001]);\n\n\t // Shortcuts\n\t var derivedKeyWords = derivedKey.words;\n\t var blockIndexWords = blockIndex.words;\n\t var keySize = cfg.keySize;\n\t var iterations = cfg.iterations;\n\n\t // Generate key\n\t while (derivedKeyWords.length < keySize) {\n\t var block = hmac.update(salt).finalize(blockIndex);\n\t hmac.reset();\n\n\t // Shortcuts\n\t var blockWords = block.words;\n\t var blockWordsLength = blockWords.length;\n\n\t // Iterations\n\t var intermediate = block;\n\t for (var i = 1; i < iterations; i++) {\n\t intermediate = hmac.finalize(intermediate);\n\t hmac.reset();\n\n\t // Shortcut\n\t var intermediateWords = intermediate.words;\n\n\t // XOR intermediate with block\n\t for (var j = 0; j < blockWordsLength; j++) {\n\t blockWords[j] ^= intermediateWords[j];\n\t }\n\t }\n\n\t derivedKey.concat(block);\n\t blockIndexWords[0]++;\n\t }\n\t derivedKey.sigBytes = keySize * 4;\n\n\t return derivedKey;\n\t }\n\t });\n\n\t /**\n\t * Computes the Password-Based Key Derivation Function 2.\n\t *\n\t * @param {WordArray|string} password The password.\n\t * @param {WordArray|string} salt A salt.\n\t * @param {Object} cfg (Optional) The configuration options to use for this computation.\n\t *\n\t * @return {WordArray} The derived key.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var key = CryptoJS.PBKDF2(password, salt);\n\t * var key = CryptoJS.PBKDF2(password, salt, { keySize: 8 });\n\t * var key = CryptoJS.PBKDF2(password, salt, { keySize: 8, iterations: 1000 });\n\t */\n\t C.PBKDF2 = function (password, salt, cfg) {\n\t return PBKDF2.create(cfg).compute(password, salt);\n\t };\n\t}());\n\n\n\treturn CryptoJS.PBKDF2;\n\n}));",";(function (root, factory, undef) {\n\tif (typeof exports === \"object\") {\n\t\t// CommonJS\n\t\tmodule.exports = exports = factory(require(\"./core\"), require(\"./enc-base64\"), require(\"./md5\"), require(\"./evpkdf\"), require(\"./cipher-core\"));\n\t}\n\telse if (typeof define === \"function\" && define.amd) {\n\t\t// AMD\n\t\tdefine([\"./core\", \"./enc-base64\", \"./md5\", \"./evpkdf\", \"./cipher-core\"], factory);\n\t}\n\telse {\n\t\t// Global (browser)\n\t\tfactory(root.CryptoJS);\n\t}\n}(this, function (CryptoJS) {\n\n\t(function () {\n\t // Shortcuts\n\t var C = CryptoJS;\n\t var C_lib = C.lib;\n\t var StreamCipher = C_lib.StreamCipher;\n\t var C_algo = C.algo;\n\n\t // Reusable objects\n\t var S = [];\n\t var C_ = [];\n\t var G = [];\n\n\t /**\n\t * Rabbit stream cipher algorithm.\n\t *\n\t * This is a legacy version that neglected to convert the key to little-endian.\n\t * This error doesn't affect the cipher's security,\n\t * but it does affect its compatibility with other implementations.\n\t */\n\t var RabbitLegacy = C_algo.RabbitLegacy = StreamCipher.extend({\n\t _doReset: function () {\n\t // Shortcuts\n\t var K = this._key.words;\n\t var iv = this.cfg.iv;\n\n\t // Generate initial state values\n\t var X = this._X = [\n\t K[0], (K[3] << 16) | (K[2] >>> 16),\n\t K[1], (K[0] << 16) | (K[3] >>> 16),\n\t K[2], (K[1] << 16) | (K[0] >>> 16),\n\t K[3], (K[2] << 16) | (K[1] >>> 16)\n\t ];\n\n\t // Generate initial counter values\n\t var C = this._C = [\n\t (K[2] << 16) | (K[2] >>> 16), (K[0] & 0xffff0000) | (K[1] & 0x0000ffff),\n\t (K[3] << 16) | (K[3] >>> 16), (K[1] & 0xffff0000) | (K[2] & 0x0000ffff),\n\t (K[0] << 16) | (K[0] >>> 16), (K[2] & 0xffff0000) | (K[3] & 0x0000ffff),\n\t (K[1] << 16) | (K[1] >>> 16), (K[3] & 0xffff0000) | (K[0] & 0x0000ffff)\n\t ];\n\n\t // Carry bit\n\t this._b = 0;\n\n\t // Iterate the system four times\n\t for (var i = 0; i < 4; i++) {\n\t nextState.call(this);\n\t }\n\n\t // Modify the counters\n\t for (var i = 0; i < 8; i++) {\n\t C[i] ^= X[(i + 4) & 7];\n\t }\n\n\t // IV setup\n\t if (iv) {\n\t // Shortcuts\n\t var IV = iv.words;\n\t var IV_0 = IV[0];\n\t var IV_1 = IV[1];\n\n\t // Generate four subvectors\n\t var i0 = (((IV_0 << 8) | (IV_0 >>> 24)) & 0x00ff00ff) | (((IV_0 << 24) | (IV_0 >>> 8)) & 0xff00ff00);\n\t var i2 = (((IV_1 << 8) | (IV_1 >>> 24)) & 0x00ff00ff) | (((IV_1 << 24) | (IV_1 >>> 8)) & 0xff00ff00);\n\t var i1 = (i0 >>> 16) | (i2 & 0xffff0000);\n\t var i3 = (i2 << 16) | (i0 & 0x0000ffff);\n\n\t // Modify counter values\n\t C[0] ^= i0;\n\t C[1] ^= i1;\n\t C[2] ^= i2;\n\t C[3] ^= i3;\n\t C[4] ^= i0;\n\t C[5] ^= i1;\n\t C[6] ^= i2;\n\t C[7] ^= i3;\n\n\t // Iterate the system four times\n\t for (var i = 0; i < 4; i++) {\n\t nextState.call(this);\n\t }\n\t }\n\t },\n\n\t _doProcessBlock: function (M, offset) {\n\t // Shortcut\n\t var X = this._X;\n\n\t // Iterate the system\n\t nextState.call(this);\n\n\t // Generate four keystream words\n\t S[0] = X[0] ^ (X[5] >>> 16) ^ (X[3] << 16);\n\t S[1] = X[2] ^ (X[7] >>> 16) ^ (X[5] << 16);\n\t S[2] = X[4] ^ (X[1] >>> 16) ^ (X[7] << 16);\n\t S[3] = X[6] ^ (X[3] >>> 16) ^ (X[1] << 16);\n\n\t for (var i = 0; i < 4; i++) {\n\t // Swap endian\n\t S[i] = (((S[i] << 8) | (S[i] >>> 24)) & 0x00ff00ff) |\n\t (((S[i] << 24) | (S[i] >>> 8)) & 0xff00ff00);\n\n\t // Encrypt\n\t M[offset + i] ^= S[i];\n\t }\n\t },\n\n\t blockSize: 128/32,\n\n\t ivSize: 64/32\n\t });\n\n\t function nextState() {\n\t // Shortcuts\n\t var X = this._X;\n\t var C = this._C;\n\n\t // Save old counter values\n\t for (var i = 0; i < 8; i++) {\n\t C_[i] = C[i];\n\t }\n\n\t // Calculate new counter values\n\t C[0] = (C[0] + 0x4d34d34d + this._b) | 0;\n\t C[1] = (C[1] + 0xd34d34d3 + ((C[0] >>> 0) < (C_[0] >>> 0) ? 1 : 0)) | 0;\n\t C[2] = (C[2] + 0x34d34d34 + ((C[1] >>> 0) < (C_[1] >>> 0) ? 1 : 0)) | 0;\n\t C[3] = (C[3] + 0x4d34d34d + ((C[2] >>> 0) < (C_[2] >>> 0) ? 1 : 0)) | 0;\n\t C[4] = (C[4] + 0xd34d34d3 + ((C[3] >>> 0) < (C_[3] >>> 0) ? 1 : 0)) | 0;\n\t C[5] = (C[5] + 0x34d34d34 + ((C[4] >>> 0) < (C_[4] >>> 0) ? 1 : 0)) | 0;\n\t C[6] = (C[6] + 0x4d34d34d + ((C[5] >>> 0) < (C_[5] >>> 0) ? 1 : 0)) | 0;\n\t C[7] = (C[7] + 0xd34d34d3 + ((C[6] >>> 0) < (C_[6] >>> 0) ? 1 : 0)) | 0;\n\t this._b = (C[7] >>> 0) < (C_[7] >>> 0) ? 1 : 0;\n\n\t // Calculate the g-values\n\t for (var i = 0; i < 8; i++) {\n\t var gx = X[i] + C[i];\n\n\t // Construct high and low argument for squaring\n\t var ga = gx & 0xffff;\n\t var gb = gx >>> 16;\n\n\t // Calculate high and low result of squaring\n\t var gh = ((((ga * ga) >>> 17) + ga * gb) >>> 15) + gb * gb;\n\t var gl = (((gx & 0xffff0000) * gx) | 0) + (((gx & 0x0000ffff) * gx) | 0);\n\n\t // High XOR low\n\t G[i] = gh ^ gl;\n\t }\n\n\t // Calculate new state values\n\t X[0] = (G[0] + ((G[7] << 16) | (G[7] >>> 16)) + ((G[6] << 16) | (G[6] >>> 16))) | 0;\n\t X[1] = (G[1] + ((G[0] << 8) | (G[0] >>> 24)) + G[7]) | 0;\n\t X[2] = (G[2] + ((G[1] << 16) | (G[1] >>> 16)) + ((G[0] << 16) | (G[0] >>> 16))) | 0;\n\t X[3] = (G[3] + ((G[2] << 8) | (G[2] >>> 24)) + G[1]) | 0;\n\t X[4] = (G[4] + ((G[3] << 16) | (G[3] >>> 16)) + ((G[2] << 16) | (G[2] >>> 16))) | 0;\n\t X[5] = (G[5] + ((G[4] << 8) | (G[4] >>> 24)) + G[3]) | 0;\n\t X[6] = (G[6] + ((G[5] << 16) | (G[5] >>> 16)) + ((G[4] << 16) | (G[4] >>> 16))) | 0;\n\t X[7] = (G[7] + ((G[6] << 8) | (G[6] >>> 24)) + G[5]) | 0;\n\t }\n\n\t /**\n\t * Shortcut functions to the cipher's object interface.\n\t *\n\t * @example\n\t *\n\t * var ciphertext = CryptoJS.RabbitLegacy.encrypt(message, key, cfg);\n\t * var plaintext = CryptoJS.RabbitLegacy.decrypt(ciphertext, key, cfg);\n\t */\n\t C.RabbitLegacy = StreamCipher._createHelper(RabbitLegacy);\n\t}());\n\n\n\treturn CryptoJS.RabbitLegacy;\n\n}));",";(function (root, factory, undef) {\n\tif (typeof exports === \"object\") {\n\t\t// CommonJS\n\t\tmodule.exports = exports = factory(require(\"./core\"), require(\"./enc-base64\"), require(\"./md5\"), require(\"./evpkdf\"), require(\"./cipher-core\"));\n\t}\n\telse if (typeof define === \"function\" && define.amd) {\n\t\t// AMD\n\t\tdefine([\"./core\", \"./enc-base64\", \"./md5\", \"./evpkdf\", \"./cipher-core\"], factory);\n\t}\n\telse {\n\t\t// Global (browser)\n\t\tfactory(root.CryptoJS);\n\t}\n}(this, function (CryptoJS) {\n\n\t(function () {\n\t // Shortcuts\n\t var C = CryptoJS;\n\t var C_lib = C.lib;\n\t var StreamCipher = C_lib.StreamCipher;\n\t var C_algo = C.algo;\n\n\t // Reusable objects\n\t var S = [];\n\t var C_ = [];\n\t var G = [];\n\n\t /**\n\t * Rabbit stream cipher algorithm\n\t */\n\t var Rabbit = C_algo.Rabbit = StreamCipher.extend({\n\t _doReset: function () {\n\t // Shortcuts\n\t var K = this._key.words;\n\t var iv = this.cfg.iv;\n\n\t // Swap endian\n\t for (var i = 0; i < 4; i++) {\n\t K[i] = (((K[i] << 8) | (K[i] >>> 24)) & 0x00ff00ff) |\n\t (((K[i] << 24) | (K[i] >>> 8)) & 0xff00ff00);\n\t }\n\n\t // Generate initial state values\n\t var X = this._X = [\n\t K[0], (K[3] << 16) | (K[2] >>> 16),\n\t K[1], (K[0] << 16) | (K[3] >>> 16),\n\t K[2], (K[1] << 16) | (K[0] >>> 16),\n\t K[3], (K[2] << 16) | (K[1] >>> 16)\n\t ];\n\n\t // Generate initial counter values\n\t var C = this._C = [\n\t (K[2] << 16) | (K[2] >>> 16), (K[0] & 0xffff0000) | (K[1] & 0x0000ffff),\n\t (K[3] << 16) | (K[3] >>> 16), (K[1] & 0xffff0000) | (K[2] & 0x0000ffff),\n\t (K[0] << 16) | (K[0] >>> 16), (K[2] & 0xffff0000) | (K[3] & 0x0000ffff),\n\t (K[1] << 16) | (K[1] >>> 16), (K[3] & 0xffff0000) | (K[0] & 0x0000ffff)\n\t ];\n\n\t // Carry bit\n\t this._b = 0;\n\n\t // Iterate the system four times\n\t for (var i = 0; i < 4; i++) {\n\t nextState.call(this);\n\t }\n\n\t // Modify the counters\n\t for (var i = 0; i < 8; i++) {\n\t C[i] ^= X[(i + 4) & 7];\n\t }\n\n\t // IV setup\n\t if (iv) {\n\t // Shortcuts\n\t var IV = iv.words;\n\t var IV_0 = IV[0];\n\t var IV_1 = IV[1];\n\n\t // Generate four subvectors\n\t var i0 = (((IV_0 << 8) | (IV_0 >>> 24)) & 0x00ff00ff) | (((IV_0 << 24) | (IV_0 >>> 8)) & 0xff00ff00);\n\t var i2 = (((IV_1 << 8) | (IV_1 >>> 24)) & 0x00ff00ff) | (((IV_1 << 24) | (IV_1 >>> 8)) & 0xff00ff00);\n\t var i1 = (i0 >>> 16) | (i2 & 0xffff0000);\n\t var i3 = (i2 << 16) | (i0 & 0x0000ffff);\n\n\t // Modify counter values\n\t C[0] ^= i0;\n\t C[1] ^= i1;\n\t C[2] ^= i2;\n\t C[3] ^= i3;\n\t C[4] ^= i0;\n\t C[5] ^= i1;\n\t C[6] ^= i2;\n\t C[7] ^= i3;\n\n\t // Iterate the system four times\n\t for (var i = 0; i < 4; i++) {\n\t nextState.call(this);\n\t }\n\t }\n\t },\n\n\t _doProcessBlock: function (M, offset) {\n\t // Shortcut\n\t var X = this._X;\n\n\t // Iterate the system\n\t nextState.call(this);\n\n\t // Generate four keystream words\n\t S[0] = X[0] ^ (X[5] >>> 16) ^ (X[3] << 16);\n\t S[1] = X[2] ^ (X[7] >>> 16) ^ (X[5] << 16);\n\t S[2] = X[4] ^ (X[1] >>> 16) ^ (X[7] << 16);\n\t S[3] = X[6] ^ (X[3] >>> 16) ^ (X[1] << 16);\n\n\t for (var i = 0; i < 4; i++) {\n\t // Swap endian\n\t S[i] = (((S[i] << 8) | (S[i] >>> 24)) & 0x00ff00ff) |\n\t (((S[i] << 24) | (S[i] >>> 8)) & 0xff00ff00);\n\n\t // Encrypt\n\t M[offset + i] ^= S[i];\n\t }\n\t },\n\n\t blockSize: 128/32,\n\n\t ivSize: 64/32\n\t });\n\n\t function nextState() {\n\t // Shortcuts\n\t var X = this._X;\n\t var C = this._C;\n\n\t // Save old counter values\n\t for (var i = 0; i < 8; i++) {\n\t C_[i] = C[i];\n\t }\n\n\t // Calculate new counter values\n\t C[0] = (C[0] + 0x4d34d34d + this._b) | 0;\n\t C[1] = (C[1] + 0xd34d34d3 + ((C[0] >>> 0) < (C_[0] >>> 0) ? 1 : 0)) | 0;\n\t C[2] = (C[2] + 0x34d34d34 + ((C[1] >>> 0) < (C_[1] >>> 0) ? 1 : 0)) | 0;\n\t C[3] = (C[3] + 0x4d34d34d + ((C[2] >>> 0) < (C_[2] >>> 0) ? 1 : 0)) | 0;\n\t C[4] = (C[4] + 0xd34d34d3 + ((C[3] >>> 0) < (C_[3] >>> 0) ? 1 : 0)) | 0;\n\t C[5] = (C[5] + 0x34d34d34 + ((C[4] >>> 0) < (C_[4] >>> 0) ? 1 : 0)) | 0;\n\t C[6] = (C[6] + 0x4d34d34d + ((C[5] >>> 0) < (C_[5] >>> 0) ? 1 : 0)) | 0;\n\t C[7] = (C[7] + 0xd34d34d3 + ((C[6] >>> 0) < (C_[6] >>> 0) ? 1 : 0)) | 0;\n\t this._b = (C[7] >>> 0) < (C_[7] >>> 0) ? 1 : 0;\n\n\t // Calculate the g-values\n\t for (var i = 0; i < 8; i++) {\n\t var gx = X[i] + C[i];\n\n\t // Construct high and low argument for squaring\n\t var ga = gx & 0xffff;\n\t var gb = gx >>> 16;\n\n\t // Calculate high and low result of squaring\n\t var gh = ((((ga * ga) >>> 17) + ga * gb) >>> 15) + gb * gb;\n\t var gl = (((gx & 0xffff0000) * gx) | 0) + (((gx & 0x0000ffff) * gx) | 0);\n\n\t // High XOR low\n\t G[i] = gh ^ gl;\n\t }\n\n\t // Calculate new state values\n\t X[0] = (G[0] + ((G[7] << 16) | (G[7] >>> 16)) + ((G[6] << 16) | (G[6] >>> 16))) | 0;\n\t X[1] = (G[1] + ((G[0] << 8) | (G[0] >>> 24)) + G[7]) | 0;\n\t X[2] = (G[2] + ((G[1] << 16) | (G[1] >>> 16)) + ((G[0] << 16) | (G[0] >>> 16))) | 0;\n\t X[3] = (G[3] + ((G[2] << 8) | (G[2] >>> 24)) + G[1]) | 0;\n\t X[4] = (G[4] + ((G[3] << 16) | (G[3] >>> 16)) + ((G[2] << 16) | (G[2] >>> 16))) | 0;\n\t X[5] = (G[5] + ((G[4] << 8) | (G[4] >>> 24)) + G[3]) | 0;\n\t X[6] = (G[6] + ((G[5] << 16) | (G[5] >>> 16)) + ((G[4] << 16) | (G[4] >>> 16))) | 0;\n\t X[7] = (G[7] + ((G[6] << 8) | (G[6] >>> 24)) + G[5]) | 0;\n\t }\n\n\t /**\n\t * Shortcut functions to the cipher's object interface.\n\t *\n\t * @example\n\t *\n\t * var ciphertext = CryptoJS.Rabbit.encrypt(message, key, cfg);\n\t * var plaintext = CryptoJS.Rabbit.decrypt(ciphertext, key, cfg);\n\t */\n\t C.Rabbit = StreamCipher._createHelper(Rabbit);\n\t}());\n\n\n\treturn CryptoJS.Rabbit;\n\n}));",";(function (root, factory, undef) {\n\tif (typeof exports === \"object\") {\n\t\t// CommonJS\n\t\tmodule.exports = exports = factory(require(\"./core\"), require(\"./enc-base64\"), require(\"./md5\"), require(\"./evpkdf\"), require(\"./cipher-core\"));\n\t}\n\telse if (typeof define === \"function\" && define.amd) {\n\t\t// AMD\n\t\tdefine([\"./core\", \"./enc-base64\", \"./md5\", \"./evpkdf\", \"./cipher-core\"], factory);\n\t}\n\telse {\n\t\t// Global (browser)\n\t\tfactory(root.CryptoJS);\n\t}\n}(this, function (CryptoJS) {\n\n\t(function () {\n\t // Shortcuts\n\t var C = CryptoJS;\n\t var C_lib = C.lib;\n\t var StreamCipher = C_lib.StreamCipher;\n\t var C_algo = C.algo;\n\n\t /**\n\t * RC4 stream cipher algorithm.\n\t */\n\t var RC4 = C_algo.RC4 = StreamCipher.extend({\n\t _doReset: function () {\n\t // Shortcuts\n\t var key = this._key;\n\t var keyWords = key.words;\n\t var keySigBytes = key.sigBytes;\n\n\t // Init sbox\n\t var S = this._S = [];\n\t for (var i = 0; i < 256; i++) {\n\t S[i] = i;\n\t }\n\n\t // Key setup\n\t for (var i = 0, j = 0; i < 256; i++) {\n\t var keyByteIndex = i % keySigBytes;\n\t var keyByte = (keyWords[keyByteIndex >>> 2] >>> (24 - (keyByteIndex % 4) * 8)) & 0xff;\n\n\t j = (j + S[i] + keyByte) % 256;\n\n\t // Swap\n\t var t = S[i];\n\t S[i] = S[j];\n\t S[j] = t;\n\t }\n\n\t // Counters\n\t this._i = this._j = 0;\n\t },\n\n\t _doProcessBlock: function (M, offset) {\n\t M[offset] ^= generateKeystreamWord.call(this);\n\t },\n\n\t keySize: 256/32,\n\n\t ivSize: 0\n\t });\n\n\t function generateKeystreamWord() {\n\t // Shortcuts\n\t var S = this._S;\n\t var i = this._i;\n\t var j = this._j;\n\n\t // Generate keystream word\n\t var keystreamWord = 0;\n\t for (var n = 0; n < 4; n++) {\n\t i = (i + 1) % 256;\n\t j = (j + S[i]) % 256;\n\n\t // Swap\n\t var t = S[i];\n\t S[i] = S[j];\n\t S[j] = t;\n\n\t keystreamWord |= S[(S[i] + S[j]) % 256] << (24 - n * 8);\n\t }\n\n\t // Update counters\n\t this._i = i;\n\t this._j = j;\n\n\t return keystreamWord;\n\t }\n\n\t /**\n\t * Shortcut functions to the cipher's object interface.\n\t *\n\t * @example\n\t *\n\t * var ciphertext = CryptoJS.RC4.encrypt(message, key, cfg);\n\t * var plaintext = CryptoJS.RC4.decrypt(ciphertext, key, cfg);\n\t */\n\t C.RC4 = StreamCipher._createHelper(RC4);\n\n\t /**\n\t * Modified RC4 stream cipher algorithm.\n\t */\n\t var RC4Drop = C_algo.RC4Drop = RC4.extend({\n\t /**\n\t * Configuration options.\n\t *\n\t * @property {number} drop The number of keystream words to drop. Default 192\n\t */\n\t cfg: RC4.cfg.extend({\n\t drop: 192\n\t }),\n\n\t _doReset: function () {\n\t RC4._doReset.call(this);\n\n\t // Drop\n\t for (var i = this.cfg.drop; i > 0; i--) {\n\t generateKeystreamWord.call(this);\n\t }\n\t }\n\t });\n\n\t /**\n\t * Shortcut functions to the cipher's object interface.\n\t *\n\t * @example\n\t *\n\t * var ciphertext = CryptoJS.RC4Drop.encrypt(message, key, cfg);\n\t * var plaintext = CryptoJS.RC4Drop.decrypt(ciphertext, key, cfg);\n\t */\n\t C.RC4Drop = StreamCipher._createHelper(RC4Drop);\n\t}());\n\n\n\treturn CryptoJS.RC4;\n\n}));",";(function (root, factory) {\n\tif (typeof exports === \"object\") {\n\t\t// CommonJS\n\t\tmodule.exports = exports = factory(require(\"./core\"));\n\t}\n\telse if (typeof define === \"function\" && define.amd) {\n\t\t// AMD\n\t\tdefine([\"./core\"], factory);\n\t}\n\telse {\n\t\t// Global (browser)\n\t\tfactory(root.CryptoJS);\n\t}\n}(this, function (CryptoJS) {\n\n\t/** @preserve\n\t(c) 2012 by Cédric Mesnil. All rights reserved.\n\n\tRedistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met:\n\n\t - Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer.\n\t - Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution.\n\n\tTHIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n\t*/\n\n\t(function (Math) {\n\t // Shortcuts\n\t var C = CryptoJS;\n\t var C_lib = C.lib;\n\t var WordArray = C_lib.WordArray;\n\t var Hasher = C_lib.Hasher;\n\t var C_algo = C.algo;\n\n\t // Constants table\n\t var _zl = WordArray.create([\n\t 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15,\n\t 7, 4, 13, 1, 10, 6, 15, 3, 12, 0, 9, 5, 2, 14, 11, 8,\n\t 3, 10, 14, 4, 9, 15, 8, 1, 2, 7, 0, 6, 13, 11, 5, 12,\n\t 1, 9, 11, 10, 0, 8, 12, 4, 13, 3, 7, 15, 14, 5, 6, 2,\n\t 4, 0, 5, 9, 7, 12, 2, 10, 14, 1, 3, 8, 11, 6, 15, 13]);\n\t var _zr = WordArray.create([\n\t 5, 14, 7, 0, 9, 2, 11, 4, 13, 6, 15, 8, 1, 10, 3, 12,\n\t 6, 11, 3, 7, 0, 13, 5, 10, 14, 15, 8, 12, 4, 9, 1, 2,\n\t 15, 5, 1, 3, 7, 14, 6, 9, 11, 8, 12, 2, 10, 0, 4, 13,\n\t 8, 6, 4, 1, 3, 11, 15, 0, 5, 12, 2, 13, 9, 7, 10, 14,\n\t 12, 15, 10, 4, 1, 5, 8, 7, 6, 2, 13, 14, 0, 3, 9, 11]);\n\t var _sl = WordArray.create([\n\t 11, 14, 15, 12, 5, 8, 7, 9, 11, 13, 14, 15, 6, 7, 9, 8,\n\t 7, 6, 8, 13, 11, 9, 7, 15, 7, 12, 15, 9, 11, 7, 13, 12,\n\t 11, 13, 6, 7, 14, 9, 13, 15, 14, 8, 13, 6, 5, 12, 7, 5,\n\t 11, 12, 14, 15, 14, 15, 9, 8, 9, 14, 5, 6, 8, 6, 5, 12,\n\t 9, 15, 5, 11, 6, 8, 13, 12, 5, 12, 13, 14, 11, 8, 5, 6 ]);\n\t var _sr = WordArray.create([\n\t 8, 9, 9, 11, 13, 15, 15, 5, 7, 7, 8, 11, 14, 14, 12, 6,\n\t 9, 13, 15, 7, 12, 8, 9, 11, 7, 7, 12, 7, 6, 15, 13, 11,\n\t 9, 7, 15, 11, 8, 6, 6, 14, 12, 13, 5, 14, 13, 13, 7, 5,\n\t 15, 5, 8, 11, 14, 14, 6, 14, 6, 9, 12, 9, 12, 5, 15, 8,\n\t 8, 5, 12, 9, 12, 5, 14, 6, 8, 13, 6, 5, 15, 13, 11, 11 ]);\n\n\t var _hl = WordArray.create([ 0x00000000, 0x5A827999, 0x6ED9EBA1, 0x8F1BBCDC, 0xA953FD4E]);\n\t var _hr = WordArray.create([ 0x50A28BE6, 0x5C4DD124, 0x6D703EF3, 0x7A6D76E9, 0x00000000]);\n\n\t /**\n\t * RIPEMD160 hash algorithm.\n\t */\n\t var RIPEMD160 = C_algo.RIPEMD160 = Hasher.extend({\n\t _doReset: function () {\n\t this._hash = WordArray.create([0x67452301, 0xEFCDAB89, 0x98BADCFE, 0x10325476, 0xC3D2E1F0]);\n\t },\n\n\t _doProcessBlock: function (M, offset) {\n\n\t // Swap endian\n\t for (var i = 0; i < 16; i++) {\n\t // Shortcuts\n\t var offset_i = offset + i;\n\t var M_offset_i = M[offset_i];\n\n\t // Swap\n\t M[offset_i] = (\n\t (((M_offset_i << 8) | (M_offset_i >>> 24)) & 0x00ff00ff) |\n\t (((M_offset_i << 24) | (M_offset_i >>> 8)) & 0xff00ff00)\n\t );\n\t }\n\t // Shortcut\n\t var H = this._hash.words;\n\t var hl = _hl.words;\n\t var hr = _hr.words;\n\t var zl = _zl.words;\n\t var zr = _zr.words;\n\t var sl = _sl.words;\n\t var sr = _sr.words;\n\n\t // Working variables\n\t var al, bl, cl, dl, el;\n\t var ar, br, cr, dr, er;\n\n\t ar = al = H[0];\n\t br = bl = H[1];\n\t cr = cl = H[2];\n\t dr = dl = H[3];\n\t er = el = H[4];\n\t // Computation\n\t var t;\n\t for (var i = 0; i < 80; i += 1) {\n\t t = (al + M[offset+zl[i]])|0;\n\t if (i<16){\n\t\t t += f1(bl,cl,dl) + hl[0];\n\t } else if (i<32) {\n\t\t t += f2(bl,cl,dl) + hl[1];\n\t } else if (i<48) {\n\t\t t += f3(bl,cl,dl) + hl[2];\n\t } else if (i<64) {\n\t\t t += f4(bl,cl,dl) + hl[3];\n\t } else {// if (i<80) {\n\t\t t += f5(bl,cl,dl) + hl[4];\n\t }\n\t t = t|0;\n\t t = rotl(t,sl[i]);\n\t t = (t+el)|0;\n\t al = el;\n\t el = dl;\n\t dl = rotl(cl, 10);\n\t cl = bl;\n\t bl = t;\n\n\t t = (ar + M[offset+zr[i]])|0;\n\t if (i<16){\n\t\t t += f5(br,cr,dr) + hr[0];\n\t } else if (i<32) {\n\t\t t += f4(br,cr,dr) + hr[1];\n\t } else if (i<48) {\n\t\t t += f3(br,cr,dr) + hr[2];\n\t } else if (i<64) {\n\t\t t += f2(br,cr,dr) + hr[3];\n\t } else {// if (i<80) {\n\t\t t += f1(br,cr,dr) + hr[4];\n\t }\n\t t = t|0;\n\t t = rotl(t,sr[i]) ;\n\t t = (t+er)|0;\n\t ar = er;\n\t er = dr;\n\t dr = rotl(cr, 10);\n\t cr = br;\n\t br = t;\n\t }\n\t // Intermediate hash value\n\t t = (H[1] + cl + dr)|0;\n\t H[1] = (H[2] + dl + er)|0;\n\t H[2] = (H[3] + el + ar)|0;\n\t H[3] = (H[4] + al + br)|0;\n\t H[4] = (H[0] + bl + cr)|0;\n\t H[0] = t;\n\t },\n\n\t _doFinalize: function () {\n\t // Shortcuts\n\t var data = this._data;\n\t var dataWords = data.words;\n\n\t var nBitsTotal = this._nDataBytes * 8;\n\t var nBitsLeft = data.sigBytes * 8;\n\n\t // Add padding\n\t dataWords[nBitsLeft >>> 5] |= 0x80 << (24 - nBitsLeft % 32);\n\t dataWords[(((nBitsLeft + 64) >>> 9) << 4) + 14] = (\n\t (((nBitsTotal << 8) | (nBitsTotal >>> 24)) & 0x00ff00ff) |\n\t (((nBitsTotal << 24) | (nBitsTotal >>> 8)) & 0xff00ff00)\n\t );\n\t data.sigBytes = (dataWords.length + 1) * 4;\n\n\t // Hash final blocks\n\t this._process();\n\n\t // Shortcuts\n\t var hash = this._hash;\n\t var H = hash.words;\n\n\t // Swap endian\n\t for (var i = 0; i < 5; i++) {\n\t // Shortcut\n\t var H_i = H[i];\n\n\t // Swap\n\t H[i] = (((H_i << 8) | (H_i >>> 24)) & 0x00ff00ff) |\n\t (((H_i << 24) | (H_i >>> 8)) & 0xff00ff00);\n\t }\n\n\t // Return final computed hash\n\t return hash;\n\t },\n\n\t clone: function () {\n\t var clone = Hasher.clone.call(this);\n\t clone._hash = this._hash.clone();\n\n\t return clone;\n\t }\n\t });\n\n\n\t function f1(x, y, z) {\n\t return ((x) ^ (y) ^ (z));\n\n\t }\n\n\t function f2(x, y, z) {\n\t return (((x)&(y)) | ((~x)&(z)));\n\t }\n\n\t function f3(x, y, z) {\n\t return (((x) | (~(y))) ^ (z));\n\t }\n\n\t function f4(x, y, z) {\n\t return (((x) & (z)) | ((y)&(~(z))));\n\t }\n\n\t function f5(x, y, z) {\n\t return ((x) ^ ((y) |(~(z))));\n\n\t }\n\n\t function rotl(x,n) {\n\t return (x<>>(32-n));\n\t }\n\n\n\t /**\n\t * Shortcut function to the hasher's object interface.\n\t *\n\t * @param {WordArray|string} message The message to hash.\n\t *\n\t * @return {WordArray} The hash.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var hash = CryptoJS.RIPEMD160('message');\n\t * var hash = CryptoJS.RIPEMD160(wordArray);\n\t */\n\t C.RIPEMD160 = Hasher._createHelper(RIPEMD160);\n\n\t /**\n\t * Shortcut function to the HMAC's object interface.\n\t *\n\t * @param {WordArray|string} message The message to hash.\n\t * @param {WordArray|string} key The secret key.\n\t *\n\t * @return {WordArray} The HMAC.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var hmac = CryptoJS.HmacRIPEMD160(message, key);\n\t */\n\t C.HmacRIPEMD160 = Hasher._createHmacHelper(RIPEMD160);\n\t}(Math));\n\n\n\treturn CryptoJS.RIPEMD160;\n\n}));",";(function (root, factory) {\n\tif (typeof exports === \"object\") {\n\t\t// CommonJS\n\t\tmodule.exports = exports = factory(require(\"./core\"));\n\t}\n\telse if (typeof define === \"function\" && define.amd) {\n\t\t// AMD\n\t\tdefine([\"./core\"], factory);\n\t}\n\telse {\n\t\t// Global (browser)\n\t\tfactory(root.CryptoJS);\n\t}\n}(this, function (CryptoJS) {\n\n\t(function () {\n\t // Shortcuts\n\t var C = CryptoJS;\n\t var C_lib = C.lib;\n\t var WordArray = C_lib.WordArray;\n\t var Hasher = C_lib.Hasher;\n\t var C_algo = C.algo;\n\n\t // Reusable object\n\t var W = [];\n\n\t /**\n\t * SHA-1 hash algorithm.\n\t */\n\t var SHA1 = C_algo.SHA1 = Hasher.extend({\n\t _doReset: function () {\n\t this._hash = new WordArray.init([\n\t 0x67452301, 0xefcdab89,\n\t 0x98badcfe, 0x10325476,\n\t 0xc3d2e1f0\n\t ]);\n\t },\n\n\t _doProcessBlock: function (M, offset) {\n\t // Shortcut\n\t var H = this._hash.words;\n\n\t // Working variables\n\t var a = H[0];\n\t var b = H[1];\n\t var c = H[2];\n\t var d = H[3];\n\t var e = H[4];\n\n\t // Computation\n\t for (var i = 0; i < 80; i++) {\n\t if (i < 16) {\n\t W[i] = M[offset + i] | 0;\n\t } else {\n\t var n = W[i - 3] ^ W[i - 8] ^ W[i - 14] ^ W[i - 16];\n\t W[i] = (n << 1) | (n >>> 31);\n\t }\n\n\t var t = ((a << 5) | (a >>> 27)) + e + W[i];\n\t if (i < 20) {\n\t t += ((b & c) | (~b & d)) + 0x5a827999;\n\t } else if (i < 40) {\n\t t += (b ^ c ^ d) + 0x6ed9eba1;\n\t } else if (i < 60) {\n\t t += ((b & c) | (b & d) | (c & d)) - 0x70e44324;\n\t } else /* if (i < 80) */ {\n\t t += (b ^ c ^ d) - 0x359d3e2a;\n\t }\n\n\t e = d;\n\t d = c;\n\t c = (b << 30) | (b >>> 2);\n\t b = a;\n\t a = t;\n\t }\n\n\t // Intermediate hash value\n\t H[0] = (H[0] + a) | 0;\n\t H[1] = (H[1] + b) | 0;\n\t H[2] = (H[2] + c) | 0;\n\t H[3] = (H[3] + d) | 0;\n\t H[4] = (H[4] + e) | 0;\n\t },\n\n\t _doFinalize: function () {\n\t // Shortcuts\n\t var data = this._data;\n\t var dataWords = data.words;\n\n\t var nBitsTotal = this._nDataBytes * 8;\n\t var nBitsLeft = data.sigBytes * 8;\n\n\t // Add padding\n\t dataWords[nBitsLeft >>> 5] |= 0x80 << (24 - nBitsLeft % 32);\n\t dataWords[(((nBitsLeft + 64) >>> 9) << 4) + 14] = Math.floor(nBitsTotal / 0x100000000);\n\t dataWords[(((nBitsLeft + 64) >>> 9) << 4) + 15] = nBitsTotal;\n\t data.sigBytes = dataWords.length * 4;\n\n\t // Hash final blocks\n\t this._process();\n\n\t // Return final computed hash\n\t return this._hash;\n\t },\n\n\t clone: function () {\n\t var clone = Hasher.clone.call(this);\n\t clone._hash = this._hash.clone();\n\n\t return clone;\n\t }\n\t });\n\n\t /**\n\t * Shortcut function to the hasher's object interface.\n\t *\n\t * @param {WordArray|string} message The message to hash.\n\t *\n\t * @return {WordArray} The hash.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var hash = CryptoJS.SHA1('message');\n\t * var hash = CryptoJS.SHA1(wordArray);\n\t */\n\t C.SHA1 = Hasher._createHelper(SHA1);\n\n\t /**\n\t * Shortcut function to the HMAC's object interface.\n\t *\n\t * @param {WordArray|string} message The message to hash.\n\t * @param {WordArray|string} key The secret key.\n\t *\n\t * @return {WordArray} The HMAC.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var hmac = CryptoJS.HmacSHA1(message, key);\n\t */\n\t C.HmacSHA1 = Hasher._createHmacHelper(SHA1);\n\t}());\n\n\n\treturn CryptoJS.SHA1;\n\n}));",";(function (root, factory, undef) {\n\tif (typeof exports === \"object\") {\n\t\t// CommonJS\n\t\tmodule.exports = exports = factory(require(\"./core\"), require(\"./sha256\"));\n\t}\n\telse if (typeof define === \"function\" && define.amd) {\n\t\t// AMD\n\t\tdefine([\"./core\", \"./sha256\"], factory);\n\t}\n\telse {\n\t\t// Global (browser)\n\t\tfactory(root.CryptoJS);\n\t}\n}(this, function (CryptoJS) {\n\n\t(function () {\n\t // Shortcuts\n\t var C = CryptoJS;\n\t var C_lib = C.lib;\n\t var WordArray = C_lib.WordArray;\n\t var C_algo = C.algo;\n\t var SHA256 = C_algo.SHA256;\n\n\t /**\n\t * SHA-224 hash algorithm.\n\t */\n\t var SHA224 = C_algo.SHA224 = SHA256.extend({\n\t _doReset: function () {\n\t this._hash = new WordArray.init([\n\t 0xc1059ed8, 0x367cd507, 0x3070dd17, 0xf70e5939,\n\t 0xffc00b31, 0x68581511, 0x64f98fa7, 0xbefa4fa4\n\t ]);\n\t },\n\n\t _doFinalize: function () {\n\t var hash = SHA256._doFinalize.call(this);\n\n\t hash.sigBytes -= 4;\n\n\t return hash;\n\t }\n\t });\n\n\t /**\n\t * Shortcut function to the hasher's object interface.\n\t *\n\t * @param {WordArray|string} message The message to hash.\n\t *\n\t * @return {WordArray} The hash.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var hash = CryptoJS.SHA224('message');\n\t * var hash = CryptoJS.SHA224(wordArray);\n\t */\n\t C.SHA224 = SHA256._createHelper(SHA224);\n\n\t /**\n\t * Shortcut function to the HMAC's object interface.\n\t *\n\t * @param {WordArray|string} message The message to hash.\n\t * @param {WordArray|string} key The secret key.\n\t *\n\t * @return {WordArray} The HMAC.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var hmac = CryptoJS.HmacSHA224(message, key);\n\t */\n\t C.HmacSHA224 = SHA256._createHmacHelper(SHA224);\n\t}());\n\n\n\treturn CryptoJS.SHA224;\n\n}));",";(function (root, factory) {\n\tif (typeof exports === \"object\") {\n\t\t// CommonJS\n\t\tmodule.exports = exports = factory(require(\"./core\"));\n\t}\n\telse if (typeof define === \"function\" && define.amd) {\n\t\t// AMD\n\t\tdefine([\"./core\"], factory);\n\t}\n\telse {\n\t\t// Global (browser)\n\t\tfactory(root.CryptoJS);\n\t}\n}(this, function (CryptoJS) {\n\n\t(function (Math) {\n\t // Shortcuts\n\t var C = CryptoJS;\n\t var C_lib = C.lib;\n\t var WordArray = C_lib.WordArray;\n\t var Hasher = C_lib.Hasher;\n\t var C_algo = C.algo;\n\n\t // Initialization and round constants tables\n\t var H = [];\n\t var K = [];\n\n\t // Compute constants\n\t (function () {\n\t function isPrime(n) {\n\t var sqrtN = Math.sqrt(n);\n\t for (var factor = 2; factor <= sqrtN; factor++) {\n\t if (!(n % factor)) {\n\t return false;\n\t }\n\t }\n\n\t return true;\n\t }\n\n\t function getFractionalBits(n) {\n\t return ((n - (n | 0)) * 0x100000000) | 0;\n\t }\n\n\t var n = 2;\n\t var nPrime = 0;\n\t while (nPrime < 64) {\n\t if (isPrime(n)) {\n\t if (nPrime < 8) {\n\t H[nPrime] = getFractionalBits(Math.pow(n, 1 / 2));\n\t }\n\t K[nPrime] = getFractionalBits(Math.pow(n, 1 / 3));\n\n\t nPrime++;\n\t }\n\n\t n++;\n\t }\n\t }());\n\n\t // Reusable object\n\t var W = [];\n\n\t /**\n\t * SHA-256 hash algorithm.\n\t */\n\t var SHA256 = C_algo.SHA256 = Hasher.extend({\n\t _doReset: function () {\n\t this._hash = new WordArray.init(H.slice(0));\n\t },\n\n\t _doProcessBlock: function (M, offset) {\n\t // Shortcut\n\t var H = this._hash.words;\n\n\t // Working variables\n\t var a = H[0];\n\t var b = H[1];\n\t var c = H[2];\n\t var d = H[3];\n\t var e = H[4];\n\t var f = H[5];\n\t var g = H[6];\n\t var h = H[7];\n\n\t // Computation\n\t for (var i = 0; i < 64; i++) {\n\t if (i < 16) {\n\t W[i] = M[offset + i] | 0;\n\t } else {\n\t var gamma0x = W[i - 15];\n\t var gamma0 = ((gamma0x << 25) | (gamma0x >>> 7)) ^\n\t ((gamma0x << 14) | (gamma0x >>> 18)) ^\n\t (gamma0x >>> 3);\n\n\t var gamma1x = W[i - 2];\n\t var gamma1 = ((gamma1x << 15) | (gamma1x >>> 17)) ^\n\t ((gamma1x << 13) | (gamma1x >>> 19)) ^\n\t (gamma1x >>> 10);\n\n\t W[i] = gamma0 + W[i - 7] + gamma1 + W[i - 16];\n\t }\n\n\t var ch = (e & f) ^ (~e & g);\n\t var maj = (a & b) ^ (a & c) ^ (b & c);\n\n\t var sigma0 = ((a << 30) | (a >>> 2)) ^ ((a << 19) | (a >>> 13)) ^ ((a << 10) | (a >>> 22));\n\t var sigma1 = ((e << 26) | (e >>> 6)) ^ ((e << 21) | (e >>> 11)) ^ ((e << 7) | (e >>> 25));\n\n\t var t1 = h + sigma1 + ch + K[i] + W[i];\n\t var t2 = sigma0 + maj;\n\n\t h = g;\n\t g = f;\n\t f = e;\n\t e = (d + t1) | 0;\n\t d = c;\n\t c = b;\n\t b = a;\n\t a = (t1 + t2) | 0;\n\t }\n\n\t // Intermediate hash value\n\t H[0] = (H[0] + a) | 0;\n\t H[1] = (H[1] + b) | 0;\n\t H[2] = (H[2] + c) | 0;\n\t H[3] = (H[3] + d) | 0;\n\t H[4] = (H[4] + e) | 0;\n\t H[5] = (H[5] + f) | 0;\n\t H[6] = (H[6] + g) | 0;\n\t H[7] = (H[7] + h) | 0;\n\t },\n\n\t _doFinalize: function () {\n\t // Shortcuts\n\t var data = this._data;\n\t var dataWords = data.words;\n\n\t var nBitsTotal = this._nDataBytes * 8;\n\t var nBitsLeft = data.sigBytes * 8;\n\n\t // Add padding\n\t dataWords[nBitsLeft >>> 5] |= 0x80 << (24 - nBitsLeft % 32);\n\t dataWords[(((nBitsLeft + 64) >>> 9) << 4) + 14] = Math.floor(nBitsTotal / 0x100000000);\n\t dataWords[(((nBitsLeft + 64) >>> 9) << 4) + 15] = nBitsTotal;\n\t data.sigBytes = dataWords.length * 4;\n\n\t // Hash final blocks\n\t this._process();\n\n\t // Return final computed hash\n\t return this._hash;\n\t },\n\n\t clone: function () {\n\t var clone = Hasher.clone.call(this);\n\t clone._hash = this._hash.clone();\n\n\t return clone;\n\t }\n\t });\n\n\t /**\n\t * Shortcut function to the hasher's object interface.\n\t *\n\t * @param {WordArray|string} message The message to hash.\n\t *\n\t * @return {WordArray} The hash.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var hash = CryptoJS.SHA256('message');\n\t * var hash = CryptoJS.SHA256(wordArray);\n\t */\n\t C.SHA256 = Hasher._createHelper(SHA256);\n\n\t /**\n\t * Shortcut function to the HMAC's object interface.\n\t *\n\t * @param {WordArray|string} message The message to hash.\n\t * @param {WordArray|string} key The secret key.\n\t *\n\t * @return {WordArray} The HMAC.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var hmac = CryptoJS.HmacSHA256(message, key);\n\t */\n\t C.HmacSHA256 = Hasher._createHmacHelper(SHA256);\n\t}(Math));\n\n\n\treturn CryptoJS.SHA256;\n\n}));",";(function (root, factory, undef) {\n\tif (typeof exports === \"object\") {\n\t\t// CommonJS\n\t\tmodule.exports = exports = factory(require(\"./core\"), require(\"./x64-core\"));\n\t}\n\telse if (typeof define === \"function\" && define.amd) {\n\t\t// AMD\n\t\tdefine([\"./core\", \"./x64-core\"], factory);\n\t}\n\telse {\n\t\t// Global (browser)\n\t\tfactory(root.CryptoJS);\n\t}\n}(this, function (CryptoJS) {\n\n\t(function (Math) {\n\t // Shortcuts\n\t var C = CryptoJS;\n\t var C_lib = C.lib;\n\t var WordArray = C_lib.WordArray;\n\t var Hasher = C_lib.Hasher;\n\t var C_x64 = C.x64;\n\t var X64Word = C_x64.Word;\n\t var C_algo = C.algo;\n\n\t // Constants tables\n\t var RHO_OFFSETS = [];\n\t var PI_INDEXES = [];\n\t var ROUND_CONSTANTS = [];\n\n\t // Compute Constants\n\t (function () {\n\t // Compute rho offset constants\n\t var x = 1, y = 0;\n\t for (var t = 0; t < 24; t++) {\n\t RHO_OFFSETS[x + 5 * y] = ((t + 1) * (t + 2) / 2) % 64;\n\n\t var newX = y % 5;\n\t var newY = (2 * x + 3 * y) % 5;\n\t x = newX;\n\t y = newY;\n\t }\n\n\t // Compute pi index constants\n\t for (var x = 0; x < 5; x++) {\n\t for (var y = 0; y < 5; y++) {\n\t PI_INDEXES[x + 5 * y] = y + ((2 * x + 3 * y) % 5) * 5;\n\t }\n\t }\n\n\t // Compute round constants\n\t var LFSR = 0x01;\n\t for (var i = 0; i < 24; i++) {\n\t var roundConstantMsw = 0;\n\t var roundConstantLsw = 0;\n\n\t for (var j = 0; j < 7; j++) {\n\t if (LFSR & 0x01) {\n\t var bitPosition = (1 << j) - 1;\n\t if (bitPosition < 32) {\n\t roundConstantLsw ^= 1 << bitPosition;\n\t } else /* if (bitPosition >= 32) */ {\n\t roundConstantMsw ^= 1 << (bitPosition - 32);\n\t }\n\t }\n\n\t // Compute next LFSR\n\t if (LFSR & 0x80) {\n\t // Primitive polynomial over GF(2): x^8 + x^6 + x^5 + x^4 + 1\n\t LFSR = (LFSR << 1) ^ 0x71;\n\t } else {\n\t LFSR <<= 1;\n\t }\n\t }\n\n\t ROUND_CONSTANTS[i] = X64Word.create(roundConstantMsw, roundConstantLsw);\n\t }\n\t }());\n\n\t // Reusable objects for temporary values\n\t var T = [];\n\t (function () {\n\t for (var i = 0; i < 25; i++) {\n\t T[i] = X64Word.create();\n\t }\n\t }());\n\n\t /**\n\t * SHA-3 hash algorithm.\n\t */\n\t var SHA3 = C_algo.SHA3 = Hasher.extend({\n\t /**\n\t * Configuration options.\n\t *\n\t * @property {number} outputLength\n\t * The desired number of bits in the output hash.\n\t * Only values permitted are: 224, 256, 384, 512.\n\t * Default: 512\n\t */\n\t cfg: Hasher.cfg.extend({\n\t outputLength: 512\n\t }),\n\n\t _doReset: function () {\n\t var state = this._state = []\n\t for (var i = 0; i < 25; i++) {\n\t state[i] = new X64Word.init();\n\t }\n\n\t this.blockSize = (1600 - 2 * this.cfg.outputLength) / 32;\n\t },\n\n\t _doProcessBlock: function (M, offset) {\n\t // Shortcuts\n\t var state = this._state;\n\t var nBlockSizeLanes = this.blockSize / 2;\n\n\t // Absorb\n\t for (var i = 0; i < nBlockSizeLanes; i++) {\n\t // Shortcuts\n\t var M2i = M[offset + 2 * i];\n\t var M2i1 = M[offset + 2 * i + 1];\n\n\t // Swap endian\n\t M2i = (\n\t (((M2i << 8) | (M2i >>> 24)) & 0x00ff00ff) |\n\t (((M2i << 24) | (M2i >>> 8)) & 0xff00ff00)\n\t );\n\t M2i1 = (\n\t (((M2i1 << 8) | (M2i1 >>> 24)) & 0x00ff00ff) |\n\t (((M2i1 << 24) | (M2i1 >>> 8)) & 0xff00ff00)\n\t );\n\n\t // Absorb message into state\n\t var lane = state[i];\n\t lane.high ^= M2i1;\n\t lane.low ^= M2i;\n\t }\n\n\t // Rounds\n\t for (var round = 0; round < 24; round++) {\n\t // Theta\n\t for (var x = 0; x < 5; x++) {\n\t // Mix column lanes\n\t var tMsw = 0, tLsw = 0;\n\t for (var y = 0; y < 5; y++) {\n\t var lane = state[x + 5 * y];\n\t tMsw ^= lane.high;\n\t tLsw ^= lane.low;\n\t }\n\n\t // Temporary values\n\t var Tx = T[x];\n\t Tx.high = tMsw;\n\t Tx.low = tLsw;\n\t }\n\t for (var x = 0; x < 5; x++) {\n\t // Shortcuts\n\t var Tx4 = T[(x + 4) % 5];\n\t var Tx1 = T[(x + 1) % 5];\n\t var Tx1Msw = Tx1.high;\n\t var Tx1Lsw = Tx1.low;\n\n\t // Mix surrounding columns\n\t var tMsw = Tx4.high ^ ((Tx1Msw << 1) | (Tx1Lsw >>> 31));\n\t var tLsw = Tx4.low ^ ((Tx1Lsw << 1) | (Tx1Msw >>> 31));\n\t for (var y = 0; y < 5; y++) {\n\t var lane = state[x + 5 * y];\n\t lane.high ^= tMsw;\n\t lane.low ^= tLsw;\n\t }\n\t }\n\n\t // Rho Pi\n\t for (var laneIndex = 1; laneIndex < 25; laneIndex++) {\n\t var tMsw;\n\t var tLsw;\n\n\t // Shortcuts\n\t var lane = state[laneIndex];\n\t var laneMsw = lane.high;\n\t var laneLsw = lane.low;\n\t var rhoOffset = RHO_OFFSETS[laneIndex];\n\n\t // Rotate lanes\n\t if (rhoOffset < 32) {\n\t tMsw = (laneMsw << rhoOffset) | (laneLsw >>> (32 - rhoOffset));\n\t tLsw = (laneLsw << rhoOffset) | (laneMsw >>> (32 - rhoOffset));\n\t } else /* if (rhoOffset >= 32) */ {\n\t tMsw = (laneLsw << (rhoOffset - 32)) | (laneMsw >>> (64 - rhoOffset));\n\t tLsw = (laneMsw << (rhoOffset - 32)) | (laneLsw >>> (64 - rhoOffset));\n\t }\n\n\t // Transpose lanes\n\t var TPiLane = T[PI_INDEXES[laneIndex]];\n\t TPiLane.high = tMsw;\n\t TPiLane.low = tLsw;\n\t }\n\n\t // Rho pi at x = y = 0\n\t var T0 = T[0];\n\t var state0 = state[0];\n\t T0.high = state0.high;\n\t T0.low = state0.low;\n\n\t // Chi\n\t for (var x = 0; x < 5; x++) {\n\t for (var y = 0; y < 5; y++) {\n\t // Shortcuts\n\t var laneIndex = x + 5 * y;\n\t var lane = state[laneIndex];\n\t var TLane = T[laneIndex];\n\t var Tx1Lane = T[((x + 1) % 5) + 5 * y];\n\t var Tx2Lane = T[((x + 2) % 5) + 5 * y];\n\n\t // Mix rows\n\t lane.high = TLane.high ^ (~Tx1Lane.high & Tx2Lane.high);\n\t lane.low = TLane.low ^ (~Tx1Lane.low & Tx2Lane.low);\n\t }\n\t }\n\n\t // Iota\n\t var lane = state[0];\n\t var roundConstant = ROUND_CONSTANTS[round];\n\t lane.high ^= roundConstant.high;\n\t lane.low ^= roundConstant.low;\n\t }\n\t },\n\n\t _doFinalize: function () {\n\t // Shortcuts\n\t var data = this._data;\n\t var dataWords = data.words;\n\t var nBitsTotal = this._nDataBytes * 8;\n\t var nBitsLeft = data.sigBytes * 8;\n\t var blockSizeBits = this.blockSize * 32;\n\n\t // Add padding\n\t dataWords[nBitsLeft >>> 5] |= 0x1 << (24 - nBitsLeft % 32);\n\t dataWords[((Math.ceil((nBitsLeft + 1) / blockSizeBits) * blockSizeBits) >>> 5) - 1] |= 0x80;\n\t data.sigBytes = dataWords.length * 4;\n\n\t // Hash final blocks\n\t this._process();\n\n\t // Shortcuts\n\t var state = this._state;\n\t var outputLengthBytes = this.cfg.outputLength / 8;\n\t var outputLengthLanes = outputLengthBytes / 8;\n\n\t // Squeeze\n\t var hashWords = [];\n\t for (var i = 0; i < outputLengthLanes; i++) {\n\t // Shortcuts\n\t var lane = state[i];\n\t var laneMsw = lane.high;\n\t var laneLsw = lane.low;\n\n\t // Swap endian\n\t laneMsw = (\n\t (((laneMsw << 8) | (laneMsw >>> 24)) & 0x00ff00ff) |\n\t (((laneMsw << 24) | (laneMsw >>> 8)) & 0xff00ff00)\n\t );\n\t laneLsw = (\n\t (((laneLsw << 8) | (laneLsw >>> 24)) & 0x00ff00ff) |\n\t (((laneLsw << 24) | (laneLsw >>> 8)) & 0xff00ff00)\n\t );\n\n\t // Squeeze state to retrieve hash\n\t hashWords.push(laneLsw);\n\t hashWords.push(laneMsw);\n\t }\n\n\t // Return final computed hash\n\t return new WordArray.init(hashWords, outputLengthBytes);\n\t },\n\n\t clone: function () {\n\t var clone = Hasher.clone.call(this);\n\n\t var state = clone._state = this._state.slice(0);\n\t for (var i = 0; i < 25; i++) {\n\t state[i] = state[i].clone();\n\t }\n\n\t return clone;\n\t }\n\t });\n\n\t /**\n\t * Shortcut function to the hasher's object interface.\n\t *\n\t * @param {WordArray|string} message The message to hash.\n\t *\n\t * @return {WordArray} The hash.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var hash = CryptoJS.SHA3('message');\n\t * var hash = CryptoJS.SHA3(wordArray);\n\t */\n\t C.SHA3 = Hasher._createHelper(SHA3);\n\n\t /**\n\t * Shortcut function to the HMAC's object interface.\n\t *\n\t * @param {WordArray|string} message The message to hash.\n\t * @param {WordArray|string} key The secret key.\n\t *\n\t * @return {WordArray} The HMAC.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var hmac = CryptoJS.HmacSHA3(message, key);\n\t */\n\t C.HmacSHA3 = Hasher._createHmacHelper(SHA3);\n\t}(Math));\n\n\n\treturn CryptoJS.SHA3;\n\n}));",";(function (root, factory, undef) {\n\tif (typeof exports === \"object\") {\n\t\t// CommonJS\n\t\tmodule.exports = exports = factory(require(\"./core\"), require(\"./x64-core\"), require(\"./sha512\"));\n\t}\n\telse if (typeof define === \"function\" && define.amd) {\n\t\t// AMD\n\t\tdefine([\"./core\", \"./x64-core\", \"./sha512\"], factory);\n\t}\n\telse {\n\t\t// Global (browser)\n\t\tfactory(root.CryptoJS);\n\t}\n}(this, function (CryptoJS) {\n\n\t(function () {\n\t // Shortcuts\n\t var C = CryptoJS;\n\t var C_x64 = C.x64;\n\t var X64Word = C_x64.Word;\n\t var X64WordArray = C_x64.WordArray;\n\t var C_algo = C.algo;\n\t var SHA512 = C_algo.SHA512;\n\n\t /**\n\t * SHA-384 hash algorithm.\n\t */\n\t var SHA384 = C_algo.SHA384 = SHA512.extend({\n\t _doReset: function () {\n\t this._hash = new X64WordArray.init([\n\t new X64Word.init(0xcbbb9d5d, 0xc1059ed8), new X64Word.init(0x629a292a, 0x367cd507),\n\t new X64Word.init(0x9159015a, 0x3070dd17), new X64Word.init(0x152fecd8, 0xf70e5939),\n\t new X64Word.init(0x67332667, 0xffc00b31), new X64Word.init(0x8eb44a87, 0x68581511),\n\t new X64Word.init(0xdb0c2e0d, 0x64f98fa7), new X64Word.init(0x47b5481d, 0xbefa4fa4)\n\t ]);\n\t },\n\n\t _doFinalize: function () {\n\t var hash = SHA512._doFinalize.call(this);\n\n\t hash.sigBytes -= 16;\n\n\t return hash;\n\t }\n\t });\n\n\t /**\n\t * Shortcut function to the hasher's object interface.\n\t *\n\t * @param {WordArray|string} message The message to hash.\n\t *\n\t * @return {WordArray} The hash.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var hash = CryptoJS.SHA384('message');\n\t * var hash = CryptoJS.SHA384(wordArray);\n\t */\n\t C.SHA384 = SHA512._createHelper(SHA384);\n\n\t /**\n\t * Shortcut function to the HMAC's object interface.\n\t *\n\t * @param {WordArray|string} message The message to hash.\n\t * @param {WordArray|string} key The secret key.\n\t *\n\t * @return {WordArray} The HMAC.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var hmac = CryptoJS.HmacSHA384(message, key);\n\t */\n\t C.HmacSHA384 = SHA512._createHmacHelper(SHA384);\n\t}());\n\n\n\treturn CryptoJS.SHA384;\n\n}));",";(function (root, factory, undef) {\n\tif (typeof exports === \"object\") {\n\t\t// CommonJS\n\t\tmodule.exports = exports = factory(require(\"./core\"), require(\"./x64-core\"));\n\t}\n\telse if (typeof define === \"function\" && define.amd) {\n\t\t// AMD\n\t\tdefine([\"./core\", \"./x64-core\"], factory);\n\t}\n\telse {\n\t\t// Global (browser)\n\t\tfactory(root.CryptoJS);\n\t}\n}(this, function (CryptoJS) {\n\n\t(function () {\n\t // Shortcuts\n\t var C = CryptoJS;\n\t var C_lib = C.lib;\n\t var Hasher = C_lib.Hasher;\n\t var C_x64 = C.x64;\n\t var X64Word = C_x64.Word;\n\t var X64WordArray = C_x64.WordArray;\n\t var C_algo = C.algo;\n\n\t function X64Word_create() {\n\t return X64Word.create.apply(X64Word, arguments);\n\t }\n\n\t // Constants\n\t var K = [\n\t X64Word_create(0x428a2f98, 0xd728ae22), X64Word_create(0x71374491, 0x23ef65cd),\n\t X64Word_create(0xb5c0fbcf, 0xec4d3b2f), X64Word_create(0xe9b5dba5, 0x8189dbbc),\n\t X64Word_create(0x3956c25b, 0xf348b538), X64Word_create(0x59f111f1, 0xb605d019),\n\t X64Word_create(0x923f82a4, 0xaf194f9b), X64Word_create(0xab1c5ed5, 0xda6d8118),\n\t X64Word_create(0xd807aa98, 0xa3030242), X64Word_create(0x12835b01, 0x45706fbe),\n\t X64Word_create(0x243185be, 0x4ee4b28c), X64Word_create(0x550c7dc3, 0xd5ffb4e2),\n\t X64Word_create(0x72be5d74, 0xf27b896f), X64Word_create(0x80deb1fe, 0x3b1696b1),\n\t X64Word_create(0x9bdc06a7, 0x25c71235), X64Word_create(0xc19bf174, 0xcf692694),\n\t X64Word_create(0xe49b69c1, 0x9ef14ad2), X64Word_create(0xefbe4786, 0x384f25e3),\n\t X64Word_create(0x0fc19dc6, 0x8b8cd5b5), X64Word_create(0x240ca1cc, 0x77ac9c65),\n\t X64Word_create(0x2de92c6f, 0x592b0275), X64Word_create(0x4a7484aa, 0x6ea6e483),\n\t X64Word_create(0x5cb0a9dc, 0xbd41fbd4), X64Word_create(0x76f988da, 0x831153b5),\n\t X64Word_create(0x983e5152, 0xee66dfab), X64Word_create(0xa831c66d, 0x2db43210),\n\t X64Word_create(0xb00327c8, 0x98fb213f), X64Word_create(0xbf597fc7, 0xbeef0ee4),\n\t X64Word_create(0xc6e00bf3, 0x3da88fc2), X64Word_create(0xd5a79147, 0x930aa725),\n\t X64Word_create(0x06ca6351, 0xe003826f), X64Word_create(0x14292967, 0x0a0e6e70),\n\t X64Word_create(0x27b70a85, 0x46d22ffc), X64Word_create(0x2e1b2138, 0x5c26c926),\n\t X64Word_create(0x4d2c6dfc, 0x5ac42aed), X64Word_create(0x53380d13, 0x9d95b3df),\n\t X64Word_create(0x650a7354, 0x8baf63de), X64Word_create(0x766a0abb, 0x3c77b2a8),\n\t X64Word_create(0x81c2c92e, 0x47edaee6), X64Word_create(0x92722c85, 0x1482353b),\n\t X64Word_create(0xa2bfe8a1, 0x4cf10364), X64Word_create(0xa81a664b, 0xbc423001),\n\t X64Word_create(0xc24b8b70, 0xd0f89791), X64Word_create(0xc76c51a3, 0x0654be30),\n\t X64Word_create(0xd192e819, 0xd6ef5218), X64Word_create(0xd6990624, 0x5565a910),\n\t X64Word_create(0xf40e3585, 0x5771202a), X64Word_create(0x106aa070, 0x32bbd1b8),\n\t X64Word_create(0x19a4c116, 0xb8d2d0c8), X64Word_create(0x1e376c08, 0x5141ab53),\n\t X64Word_create(0x2748774c, 0xdf8eeb99), X64Word_create(0x34b0bcb5, 0xe19b48a8),\n\t X64Word_create(0x391c0cb3, 0xc5c95a63), X64Word_create(0x4ed8aa4a, 0xe3418acb),\n\t X64Word_create(0x5b9cca4f, 0x7763e373), X64Word_create(0x682e6ff3, 0xd6b2b8a3),\n\t X64Word_create(0x748f82ee, 0x5defb2fc), X64Word_create(0x78a5636f, 0x43172f60),\n\t X64Word_create(0x84c87814, 0xa1f0ab72), X64Word_create(0x8cc70208, 0x1a6439ec),\n\t X64Word_create(0x90befffa, 0x23631e28), X64Word_create(0xa4506ceb, 0xde82bde9),\n\t X64Word_create(0xbef9a3f7, 0xb2c67915), X64Word_create(0xc67178f2, 0xe372532b),\n\t X64Word_create(0xca273ece, 0xea26619c), X64Word_create(0xd186b8c7, 0x21c0c207),\n\t X64Word_create(0xeada7dd6, 0xcde0eb1e), X64Word_create(0xf57d4f7f, 0xee6ed178),\n\t X64Word_create(0x06f067aa, 0x72176fba), X64Word_create(0x0a637dc5, 0xa2c898a6),\n\t X64Word_create(0x113f9804, 0xbef90dae), X64Word_create(0x1b710b35, 0x131c471b),\n\t X64Word_create(0x28db77f5, 0x23047d84), X64Word_create(0x32caab7b, 0x40c72493),\n\t X64Word_create(0x3c9ebe0a, 0x15c9bebc), X64Word_create(0x431d67c4, 0x9c100d4c),\n\t X64Word_create(0x4cc5d4be, 0xcb3e42b6), X64Word_create(0x597f299c, 0xfc657e2a),\n\t X64Word_create(0x5fcb6fab, 0x3ad6faec), X64Word_create(0x6c44198c, 0x4a475817)\n\t ];\n\n\t // Reusable objects\n\t var W = [];\n\t (function () {\n\t for (var i = 0; i < 80; i++) {\n\t W[i] = X64Word_create();\n\t }\n\t }());\n\n\t /**\n\t * SHA-512 hash algorithm.\n\t */\n\t var SHA512 = C_algo.SHA512 = Hasher.extend({\n\t _doReset: function () {\n\t this._hash = new X64WordArray.init([\n\t new X64Word.init(0x6a09e667, 0xf3bcc908), new X64Word.init(0xbb67ae85, 0x84caa73b),\n\t new X64Word.init(0x3c6ef372, 0xfe94f82b), new X64Word.init(0xa54ff53a, 0x5f1d36f1),\n\t new X64Word.init(0x510e527f, 0xade682d1), new X64Word.init(0x9b05688c, 0x2b3e6c1f),\n\t new X64Word.init(0x1f83d9ab, 0xfb41bd6b), new X64Word.init(0x5be0cd19, 0x137e2179)\n\t ]);\n\t },\n\n\t _doProcessBlock: function (M, offset) {\n\t // Shortcuts\n\t var H = this._hash.words;\n\n\t var H0 = H[0];\n\t var H1 = H[1];\n\t var H2 = H[2];\n\t var H3 = H[3];\n\t var H4 = H[4];\n\t var H5 = H[5];\n\t var H6 = H[6];\n\t var H7 = H[7];\n\n\t var H0h = H0.high;\n\t var H0l = H0.low;\n\t var H1h = H1.high;\n\t var H1l = H1.low;\n\t var H2h = H2.high;\n\t var H2l = H2.low;\n\t var H3h = H3.high;\n\t var H3l = H3.low;\n\t var H4h = H4.high;\n\t var H4l = H4.low;\n\t var H5h = H5.high;\n\t var H5l = H5.low;\n\t var H6h = H6.high;\n\t var H6l = H6.low;\n\t var H7h = H7.high;\n\t var H7l = H7.low;\n\n\t // Working variables\n\t var ah = H0h;\n\t var al = H0l;\n\t var bh = H1h;\n\t var bl = H1l;\n\t var ch = H2h;\n\t var cl = H2l;\n\t var dh = H3h;\n\t var dl = H3l;\n\t var eh = H4h;\n\t var el = H4l;\n\t var fh = H5h;\n\t var fl = H5l;\n\t var gh = H6h;\n\t var gl = H6l;\n\t var hh = H7h;\n\t var hl = H7l;\n\n\t // Rounds\n\t for (var i = 0; i < 80; i++) {\n\t var Wil;\n\t var Wih;\n\n\t // Shortcut\n\t var Wi = W[i];\n\n\t // Extend message\n\t if (i < 16) {\n\t Wih = Wi.high = M[offset + i * 2] | 0;\n\t Wil = Wi.low = M[offset + i * 2 + 1] | 0;\n\t } else {\n\t // Gamma0\n\t var gamma0x = W[i - 15];\n\t var gamma0xh = gamma0x.high;\n\t var gamma0xl = gamma0x.low;\n\t var gamma0h = ((gamma0xh >>> 1) | (gamma0xl << 31)) ^ ((gamma0xh >>> 8) | (gamma0xl << 24)) ^ (gamma0xh >>> 7);\n\t var gamma0l = ((gamma0xl >>> 1) | (gamma0xh << 31)) ^ ((gamma0xl >>> 8) | (gamma0xh << 24)) ^ ((gamma0xl >>> 7) | (gamma0xh << 25));\n\n\t // Gamma1\n\t var gamma1x = W[i - 2];\n\t var gamma1xh = gamma1x.high;\n\t var gamma1xl = gamma1x.low;\n\t var gamma1h = ((gamma1xh >>> 19) | (gamma1xl << 13)) ^ ((gamma1xh << 3) | (gamma1xl >>> 29)) ^ (gamma1xh >>> 6);\n\t var gamma1l = ((gamma1xl >>> 19) | (gamma1xh << 13)) ^ ((gamma1xl << 3) | (gamma1xh >>> 29)) ^ ((gamma1xl >>> 6) | (gamma1xh << 26));\n\n\t // W[i] = gamma0 + W[i - 7] + gamma1 + W[i - 16]\n\t var Wi7 = W[i - 7];\n\t var Wi7h = Wi7.high;\n\t var Wi7l = Wi7.low;\n\n\t var Wi16 = W[i - 16];\n\t var Wi16h = Wi16.high;\n\t var Wi16l = Wi16.low;\n\n\t Wil = gamma0l + Wi7l;\n\t Wih = gamma0h + Wi7h + ((Wil >>> 0) < (gamma0l >>> 0) ? 1 : 0);\n\t Wil = Wil + gamma1l;\n\t Wih = Wih + gamma1h + ((Wil >>> 0) < (gamma1l >>> 0) ? 1 : 0);\n\t Wil = Wil + Wi16l;\n\t Wih = Wih + Wi16h + ((Wil >>> 0) < (Wi16l >>> 0) ? 1 : 0);\n\n\t Wi.high = Wih;\n\t Wi.low = Wil;\n\t }\n\n\t var chh = (eh & fh) ^ (~eh & gh);\n\t var chl = (el & fl) ^ (~el & gl);\n\t var majh = (ah & bh) ^ (ah & ch) ^ (bh & ch);\n\t var majl = (al & bl) ^ (al & cl) ^ (bl & cl);\n\n\t var sigma0h = ((ah >>> 28) | (al << 4)) ^ ((ah << 30) | (al >>> 2)) ^ ((ah << 25) | (al >>> 7));\n\t var sigma0l = ((al >>> 28) | (ah << 4)) ^ ((al << 30) | (ah >>> 2)) ^ ((al << 25) | (ah >>> 7));\n\t var sigma1h = ((eh >>> 14) | (el << 18)) ^ ((eh >>> 18) | (el << 14)) ^ ((eh << 23) | (el >>> 9));\n\t var sigma1l = ((el >>> 14) | (eh << 18)) ^ ((el >>> 18) | (eh << 14)) ^ ((el << 23) | (eh >>> 9));\n\n\t // t1 = h + sigma1 + ch + K[i] + W[i]\n\t var Ki = K[i];\n\t var Kih = Ki.high;\n\t var Kil = Ki.low;\n\n\t var t1l = hl + sigma1l;\n\t var t1h = hh + sigma1h + ((t1l >>> 0) < (hl >>> 0) ? 1 : 0);\n\t var t1l = t1l + chl;\n\t var t1h = t1h + chh + ((t1l >>> 0) < (chl >>> 0) ? 1 : 0);\n\t var t1l = t1l + Kil;\n\t var t1h = t1h + Kih + ((t1l >>> 0) < (Kil >>> 0) ? 1 : 0);\n\t var t1l = t1l + Wil;\n\t var t1h = t1h + Wih + ((t1l >>> 0) < (Wil >>> 0) ? 1 : 0);\n\n\t // t2 = sigma0 + maj\n\t var t2l = sigma0l + majl;\n\t var t2h = sigma0h + majh + ((t2l >>> 0) < (sigma0l >>> 0) ? 1 : 0);\n\n\t // Update working variables\n\t hh = gh;\n\t hl = gl;\n\t gh = fh;\n\t gl = fl;\n\t fh = eh;\n\t fl = el;\n\t el = (dl + t1l) | 0;\n\t eh = (dh + t1h + ((el >>> 0) < (dl >>> 0) ? 1 : 0)) | 0;\n\t dh = ch;\n\t dl = cl;\n\t ch = bh;\n\t cl = bl;\n\t bh = ah;\n\t bl = al;\n\t al = (t1l + t2l) | 0;\n\t ah = (t1h + t2h + ((al >>> 0) < (t1l >>> 0) ? 1 : 0)) | 0;\n\t }\n\n\t // Intermediate hash value\n\t H0l = H0.low = (H0l + al);\n\t H0.high = (H0h + ah + ((H0l >>> 0) < (al >>> 0) ? 1 : 0));\n\t H1l = H1.low = (H1l + bl);\n\t H1.high = (H1h + bh + ((H1l >>> 0) < (bl >>> 0) ? 1 : 0));\n\t H2l = H2.low = (H2l + cl);\n\t H2.high = (H2h + ch + ((H2l >>> 0) < (cl >>> 0) ? 1 : 0));\n\t H3l = H3.low = (H3l + dl);\n\t H3.high = (H3h + dh + ((H3l >>> 0) < (dl >>> 0) ? 1 : 0));\n\t H4l = H4.low = (H4l + el);\n\t H4.high = (H4h + eh + ((H4l >>> 0) < (el >>> 0) ? 1 : 0));\n\t H5l = H5.low = (H5l + fl);\n\t H5.high = (H5h + fh + ((H5l >>> 0) < (fl >>> 0) ? 1 : 0));\n\t H6l = H6.low = (H6l + gl);\n\t H6.high = (H6h + gh + ((H6l >>> 0) < (gl >>> 0) ? 1 : 0));\n\t H7l = H7.low = (H7l + hl);\n\t H7.high = (H7h + hh + ((H7l >>> 0) < (hl >>> 0) ? 1 : 0));\n\t },\n\n\t _doFinalize: function () {\n\t // Shortcuts\n\t var data = this._data;\n\t var dataWords = data.words;\n\n\t var nBitsTotal = this._nDataBytes * 8;\n\t var nBitsLeft = data.sigBytes * 8;\n\n\t // Add padding\n\t dataWords[nBitsLeft >>> 5] |= 0x80 << (24 - nBitsLeft % 32);\n\t dataWords[(((nBitsLeft + 128) >>> 10) << 5) + 30] = Math.floor(nBitsTotal / 0x100000000);\n\t dataWords[(((nBitsLeft + 128) >>> 10) << 5) + 31] = nBitsTotal;\n\t data.sigBytes = dataWords.length * 4;\n\n\t // Hash final blocks\n\t this._process();\n\n\t // Convert hash to 32-bit word array before returning\n\t var hash = this._hash.toX32();\n\n\t // Return final computed hash\n\t return hash;\n\t },\n\n\t clone: function () {\n\t var clone = Hasher.clone.call(this);\n\t clone._hash = this._hash.clone();\n\n\t return clone;\n\t },\n\n\t blockSize: 1024/32\n\t });\n\n\t /**\n\t * Shortcut function to the hasher's object interface.\n\t *\n\t * @param {WordArray|string} message The message to hash.\n\t *\n\t * @return {WordArray} The hash.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var hash = CryptoJS.SHA512('message');\n\t * var hash = CryptoJS.SHA512(wordArray);\n\t */\n\t C.SHA512 = Hasher._createHelper(SHA512);\n\n\t /**\n\t * Shortcut function to the HMAC's object interface.\n\t *\n\t * @param {WordArray|string} message The message to hash.\n\t * @param {WordArray|string} key The secret key.\n\t *\n\t * @return {WordArray} The HMAC.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var hmac = CryptoJS.HmacSHA512(message, key);\n\t */\n\t C.HmacSHA512 = Hasher._createHmacHelper(SHA512);\n\t}());\n\n\n\treturn CryptoJS.SHA512;\n\n}));",";(function (root, factory, undef) {\n\tif (typeof exports === \"object\") {\n\t\t// CommonJS\n\t\tmodule.exports = exports = factory(require(\"./core\"), require(\"./enc-base64\"), require(\"./md5\"), require(\"./evpkdf\"), require(\"./cipher-core\"));\n\t}\n\telse if (typeof define === \"function\" && define.amd) {\n\t\t// AMD\n\t\tdefine([\"./core\", \"./enc-base64\", \"./md5\", \"./evpkdf\", \"./cipher-core\"], factory);\n\t}\n\telse {\n\t\t// Global (browser)\n\t\tfactory(root.CryptoJS);\n\t}\n}(this, function (CryptoJS) {\n\n\t(function () {\n\t // Shortcuts\n\t var C = CryptoJS;\n\t var C_lib = C.lib;\n\t var WordArray = C_lib.WordArray;\n\t var BlockCipher = C_lib.BlockCipher;\n\t var C_algo = C.algo;\n\n\t // Permuted Choice 1 constants\n\t var PC1 = [\n\t 57, 49, 41, 33, 25, 17, 9, 1,\n\t 58, 50, 42, 34, 26, 18, 10, 2,\n\t 59, 51, 43, 35, 27, 19, 11, 3,\n\t 60, 52, 44, 36, 63, 55, 47, 39,\n\t 31, 23, 15, 7, 62, 54, 46, 38,\n\t 30, 22, 14, 6, 61, 53, 45, 37,\n\t 29, 21, 13, 5, 28, 20, 12, 4\n\t ];\n\n\t // Permuted Choice 2 constants\n\t var PC2 = [\n\t 14, 17, 11, 24, 1, 5,\n\t 3, 28, 15, 6, 21, 10,\n\t 23, 19, 12, 4, 26, 8,\n\t 16, 7, 27, 20, 13, 2,\n\t 41, 52, 31, 37, 47, 55,\n\t 30, 40, 51, 45, 33, 48,\n\t 44, 49, 39, 56, 34, 53,\n\t 46, 42, 50, 36, 29, 32\n\t ];\n\n\t // Cumulative bit shift constants\n\t var BIT_SHIFTS = [1, 2, 4, 6, 8, 10, 12, 14, 15, 17, 19, 21, 23, 25, 27, 28];\n\n\t // SBOXes and round permutation constants\n\t var SBOX_P = [\n\t {\n\t 0x0: 0x808200,\n\t 0x10000000: 0x8000,\n\t 0x20000000: 0x808002,\n\t 0x30000000: 0x2,\n\t 0x40000000: 0x200,\n\t 0x50000000: 0x808202,\n\t 0x60000000: 0x800202,\n\t 0x70000000: 0x800000,\n\t 0x80000000: 0x202,\n\t 0x90000000: 0x800200,\n\t 0xa0000000: 0x8200,\n\t 0xb0000000: 0x808000,\n\t 0xc0000000: 0x8002,\n\t 0xd0000000: 0x800002,\n\t 0xe0000000: 0x0,\n\t 0xf0000000: 0x8202,\n\t 0x8000000: 0x0,\n\t 0x18000000: 0x808202,\n\t 0x28000000: 0x8202,\n\t 0x38000000: 0x8000,\n\t 0x48000000: 0x808200,\n\t 0x58000000: 0x200,\n\t 0x68000000: 0x808002,\n\t 0x78000000: 0x2,\n\t 0x88000000: 0x800200,\n\t 0x98000000: 0x8200,\n\t 0xa8000000: 0x808000,\n\t 0xb8000000: 0x800202,\n\t 0xc8000000: 0x800002,\n\t 0xd8000000: 0x8002,\n\t 0xe8000000: 0x202,\n\t 0xf8000000: 0x800000,\n\t 0x1: 0x8000,\n\t 0x10000001: 0x2,\n\t 0x20000001: 0x808200,\n\t 0x30000001: 0x800000,\n\t 0x40000001: 0x808002,\n\t 0x50000001: 0x8200,\n\t 0x60000001: 0x200,\n\t 0x70000001: 0x800202,\n\t 0x80000001: 0x808202,\n\t 0x90000001: 0x808000,\n\t 0xa0000001: 0x800002,\n\t 0xb0000001: 0x8202,\n\t 0xc0000001: 0x202,\n\t 0xd0000001: 0x800200,\n\t 0xe0000001: 0x8002,\n\t 0xf0000001: 0x0,\n\t 0x8000001: 0x808202,\n\t 0x18000001: 0x808000,\n\t 0x28000001: 0x800000,\n\t 0x38000001: 0x200,\n\t 0x48000001: 0x8000,\n\t 0x58000001: 0x800002,\n\t 0x68000001: 0x2,\n\t 0x78000001: 0x8202,\n\t 0x88000001: 0x8002,\n\t 0x98000001: 0x800202,\n\t 0xa8000001: 0x202,\n\t 0xb8000001: 0x808200,\n\t 0xc8000001: 0x800200,\n\t 0xd8000001: 0x0,\n\t 0xe8000001: 0x8200,\n\t 0xf8000001: 0x808002\n\t },\n\t {\n\t 0x0: 0x40084010,\n\t 0x1000000: 0x4000,\n\t 0x2000000: 0x80000,\n\t 0x3000000: 0x40080010,\n\t 0x4000000: 0x40000010,\n\t 0x5000000: 0x40084000,\n\t 0x6000000: 0x40004000,\n\t 0x7000000: 0x10,\n\t 0x8000000: 0x84000,\n\t 0x9000000: 0x40004010,\n\t 0xa000000: 0x40000000,\n\t 0xb000000: 0x84010,\n\t 0xc000000: 0x80010,\n\t 0xd000000: 0x0,\n\t 0xe000000: 0x4010,\n\t 0xf000000: 0x40080000,\n\t 0x800000: 0x40004000,\n\t 0x1800000: 0x84010,\n\t 0x2800000: 0x10,\n\t 0x3800000: 0x40004010,\n\t 0x4800000: 0x40084010,\n\t 0x5800000: 0x40000000,\n\t 0x6800000: 0x80000,\n\t 0x7800000: 0x40080010,\n\t 0x8800000: 0x80010,\n\t 0x9800000: 0x0,\n\t 0xa800000: 0x4000,\n\t 0xb800000: 0x40080000,\n\t 0xc800000: 0x40000010,\n\t 0xd800000: 0x84000,\n\t 0xe800000: 0x40084000,\n\t 0xf800000: 0x4010,\n\t 0x10000000: 0x0,\n\t 0x11000000: 0x40080010,\n\t 0x12000000: 0x40004010,\n\t 0x13000000: 0x40084000,\n\t 0x14000000: 0x40080000,\n\t 0x15000000: 0x10,\n\t 0x16000000: 0x84010,\n\t 0x17000000: 0x4000,\n\t 0x18000000: 0x4010,\n\t 0x19000000: 0x80000,\n\t 0x1a000000: 0x80010,\n\t 0x1b000000: 0x40000010,\n\t 0x1c000000: 0x84000,\n\t 0x1d000000: 0x40004000,\n\t 0x1e000000: 0x40000000,\n\t 0x1f000000: 0x40084010,\n\t 0x10800000: 0x84010,\n\t 0x11800000: 0x80000,\n\t 0x12800000: 0x40080000,\n\t 0x13800000: 0x4000,\n\t 0x14800000: 0x40004000,\n\t 0x15800000: 0x40084010,\n\t 0x16800000: 0x10,\n\t 0x17800000: 0x40000000,\n\t 0x18800000: 0x40084000,\n\t 0x19800000: 0x40000010,\n\t 0x1a800000: 0x40004010,\n\t 0x1b800000: 0x80010,\n\t 0x1c800000: 0x0,\n\t 0x1d800000: 0x4010,\n\t 0x1e800000: 0x40080010,\n\t 0x1f800000: 0x84000\n\t },\n\t {\n\t 0x0: 0x104,\n\t 0x100000: 0x0,\n\t 0x200000: 0x4000100,\n\t 0x300000: 0x10104,\n\t 0x400000: 0x10004,\n\t 0x500000: 0x4000004,\n\t 0x600000: 0x4010104,\n\t 0x700000: 0x4010000,\n\t 0x800000: 0x4000000,\n\t 0x900000: 0x4010100,\n\t 0xa00000: 0x10100,\n\t 0xb00000: 0x4010004,\n\t 0xc00000: 0x4000104,\n\t 0xd00000: 0x10000,\n\t 0xe00000: 0x4,\n\t 0xf00000: 0x100,\n\t 0x80000: 0x4010100,\n\t 0x180000: 0x4010004,\n\t 0x280000: 0x0,\n\t 0x380000: 0x4000100,\n\t 0x480000: 0x4000004,\n\t 0x580000: 0x10000,\n\t 0x680000: 0x10004,\n\t 0x780000: 0x104,\n\t 0x880000: 0x4,\n\t 0x980000: 0x100,\n\t 0xa80000: 0x4010000,\n\t 0xb80000: 0x10104,\n\t 0xc80000: 0x10100,\n\t 0xd80000: 0x4000104,\n\t 0xe80000: 0x4010104,\n\t 0xf80000: 0x4000000,\n\t 0x1000000: 0x4010100,\n\t 0x1100000: 0x10004,\n\t 0x1200000: 0x10000,\n\t 0x1300000: 0x4000100,\n\t 0x1400000: 0x100,\n\t 0x1500000: 0x4010104,\n\t 0x1600000: 0x4000004,\n\t 0x1700000: 0x0,\n\t 0x1800000: 0x4000104,\n\t 0x1900000: 0x4000000,\n\t 0x1a00000: 0x4,\n\t 0x1b00000: 0x10100,\n\t 0x1c00000: 0x4010000,\n\t 0x1d00000: 0x104,\n\t 0x1e00000: 0x10104,\n\t 0x1f00000: 0x4010004,\n\t 0x1080000: 0x4000000,\n\t 0x1180000: 0x104,\n\t 0x1280000: 0x4010100,\n\t 0x1380000: 0x0,\n\t 0x1480000: 0x10004,\n\t 0x1580000: 0x4000100,\n\t 0x1680000: 0x100,\n\t 0x1780000: 0x4010004,\n\t 0x1880000: 0x10000,\n\t 0x1980000: 0x4010104,\n\t 0x1a80000: 0x10104,\n\t 0x1b80000: 0x4000004,\n\t 0x1c80000: 0x4000104,\n\t 0x1d80000: 0x4010000,\n\t 0x1e80000: 0x4,\n\t 0x1f80000: 0x10100\n\t },\n\t {\n\t 0x0: 0x80401000,\n\t 0x10000: 0x80001040,\n\t 0x20000: 0x401040,\n\t 0x30000: 0x80400000,\n\t 0x40000: 0x0,\n\t 0x50000: 0x401000,\n\t 0x60000: 0x80000040,\n\t 0x70000: 0x400040,\n\t 0x80000: 0x80000000,\n\t 0x90000: 0x400000,\n\t 0xa0000: 0x40,\n\t 0xb0000: 0x80001000,\n\t 0xc0000: 0x80400040,\n\t 0xd0000: 0x1040,\n\t 0xe0000: 0x1000,\n\t 0xf0000: 0x80401040,\n\t 0x8000: 0x80001040,\n\t 0x18000: 0x40,\n\t 0x28000: 0x80400040,\n\t 0x38000: 0x80001000,\n\t 0x48000: 0x401000,\n\t 0x58000: 0x80401040,\n\t 0x68000: 0x0,\n\t 0x78000: 0x80400000,\n\t 0x88000: 0x1000,\n\t 0x98000: 0x80401000,\n\t 0xa8000: 0x400000,\n\t 0xb8000: 0x1040,\n\t 0xc8000: 0x80000000,\n\t 0xd8000: 0x400040,\n\t 0xe8000: 0x401040,\n\t 0xf8000: 0x80000040,\n\t 0x100000: 0x400040,\n\t 0x110000: 0x401000,\n\t 0x120000: 0x80000040,\n\t 0x130000: 0x0,\n\t 0x140000: 0x1040,\n\t 0x150000: 0x80400040,\n\t 0x160000: 0x80401000,\n\t 0x170000: 0x80001040,\n\t 0x180000: 0x80401040,\n\t 0x190000: 0x80000000,\n\t 0x1a0000: 0x80400000,\n\t 0x1b0000: 0x401040,\n\t 0x1c0000: 0x80001000,\n\t 0x1d0000: 0x400000,\n\t 0x1e0000: 0x40,\n\t 0x1f0000: 0x1000,\n\t 0x108000: 0x80400000,\n\t 0x118000: 0x80401040,\n\t 0x128000: 0x0,\n\t 0x138000: 0x401000,\n\t 0x148000: 0x400040,\n\t 0x158000: 0x80000000,\n\t 0x168000: 0x80001040,\n\t 0x178000: 0x40,\n\t 0x188000: 0x80000040,\n\t 0x198000: 0x1000,\n\t 0x1a8000: 0x80001000,\n\t 0x1b8000: 0x80400040,\n\t 0x1c8000: 0x1040,\n\t 0x1d8000: 0x80401000,\n\t 0x1e8000: 0x400000,\n\t 0x1f8000: 0x401040\n\t },\n\t {\n\t 0x0: 0x80,\n\t 0x1000: 0x1040000,\n\t 0x2000: 0x40000,\n\t 0x3000: 0x20000000,\n\t 0x4000: 0x20040080,\n\t 0x5000: 0x1000080,\n\t 0x6000: 0x21000080,\n\t 0x7000: 0x40080,\n\t 0x8000: 0x1000000,\n\t 0x9000: 0x20040000,\n\t 0xa000: 0x20000080,\n\t 0xb000: 0x21040080,\n\t 0xc000: 0x21040000,\n\t 0xd000: 0x0,\n\t 0xe000: 0x1040080,\n\t 0xf000: 0x21000000,\n\t 0x800: 0x1040080,\n\t 0x1800: 0x21000080,\n\t 0x2800: 0x80,\n\t 0x3800: 0x1040000,\n\t 0x4800: 0x40000,\n\t 0x5800: 0x20040080,\n\t 0x6800: 0x21040000,\n\t 0x7800: 0x20000000,\n\t 0x8800: 0x20040000,\n\t 0x9800: 0x0,\n\t 0xa800: 0x21040080,\n\t 0xb800: 0x1000080,\n\t 0xc800: 0x20000080,\n\t 0xd800: 0x21000000,\n\t 0xe800: 0x1000000,\n\t 0xf800: 0x40080,\n\t 0x10000: 0x40000,\n\t 0x11000: 0x80,\n\t 0x12000: 0x20000000,\n\t 0x13000: 0x21000080,\n\t 0x14000: 0x1000080,\n\t 0x15000: 0x21040000,\n\t 0x16000: 0x20040080,\n\t 0x17000: 0x1000000,\n\t 0x18000: 0x21040080,\n\t 0x19000: 0x21000000,\n\t 0x1a000: 0x1040000,\n\t 0x1b000: 0x20040000,\n\t 0x1c000: 0x40080,\n\t 0x1d000: 0x20000080,\n\t 0x1e000: 0x0,\n\t 0x1f000: 0x1040080,\n\t 0x10800: 0x21000080,\n\t 0x11800: 0x1000000,\n\t 0x12800: 0x1040000,\n\t 0x13800: 0x20040080,\n\t 0x14800: 0x20000000,\n\t 0x15800: 0x1040080,\n\t 0x16800: 0x80,\n\t 0x17800: 0x21040000,\n\t 0x18800: 0x40080,\n\t 0x19800: 0x21040080,\n\t 0x1a800: 0x0,\n\t 0x1b800: 0x21000000,\n\t 0x1c800: 0x1000080,\n\t 0x1d800: 0x40000,\n\t 0x1e800: 0x20040000,\n\t 0x1f800: 0x20000080\n\t },\n\t {\n\t 0x0: 0x10000008,\n\t 0x100: 0x2000,\n\t 0x200: 0x10200000,\n\t 0x300: 0x10202008,\n\t 0x400: 0x10002000,\n\t 0x500: 0x200000,\n\t 0x600: 0x200008,\n\t 0x700: 0x10000000,\n\t 0x800: 0x0,\n\t 0x900: 0x10002008,\n\t 0xa00: 0x202000,\n\t 0xb00: 0x8,\n\t 0xc00: 0x10200008,\n\t 0xd00: 0x202008,\n\t 0xe00: 0x2008,\n\t 0xf00: 0x10202000,\n\t 0x80: 0x10200000,\n\t 0x180: 0x10202008,\n\t 0x280: 0x8,\n\t 0x380: 0x200000,\n\t 0x480: 0x202008,\n\t 0x580: 0x10000008,\n\t 0x680: 0x10002000,\n\t 0x780: 0x2008,\n\t 0x880: 0x200008,\n\t 0x980: 0x2000,\n\t 0xa80: 0x10002008,\n\t 0xb80: 0x10200008,\n\t 0xc80: 0x0,\n\t 0xd80: 0x10202000,\n\t 0xe80: 0x202000,\n\t 0xf80: 0x10000000,\n\t 0x1000: 0x10002000,\n\t 0x1100: 0x10200008,\n\t 0x1200: 0x10202008,\n\t 0x1300: 0x2008,\n\t 0x1400: 0x200000,\n\t 0x1500: 0x10000000,\n\t 0x1600: 0x10000008,\n\t 0x1700: 0x202000,\n\t 0x1800: 0x202008,\n\t 0x1900: 0x0,\n\t 0x1a00: 0x8,\n\t 0x1b00: 0x10200000,\n\t 0x1c00: 0x2000,\n\t 0x1d00: 0x10002008,\n\t 0x1e00: 0x10202000,\n\t 0x1f00: 0x200008,\n\t 0x1080: 0x8,\n\t 0x1180: 0x202000,\n\t 0x1280: 0x200000,\n\t 0x1380: 0x10000008,\n\t 0x1480: 0x10002000,\n\t 0x1580: 0x2008,\n\t 0x1680: 0x10202008,\n\t 0x1780: 0x10200000,\n\t 0x1880: 0x10202000,\n\t 0x1980: 0x10200008,\n\t 0x1a80: 0x2000,\n\t 0x1b80: 0x202008,\n\t 0x1c80: 0x200008,\n\t 0x1d80: 0x0,\n\t 0x1e80: 0x10000000,\n\t 0x1f80: 0x10002008\n\t },\n\t {\n\t 0x0: 0x100000,\n\t 0x10: 0x2000401,\n\t 0x20: 0x400,\n\t 0x30: 0x100401,\n\t 0x40: 0x2100401,\n\t 0x50: 0x0,\n\t 0x60: 0x1,\n\t 0x70: 0x2100001,\n\t 0x80: 0x2000400,\n\t 0x90: 0x100001,\n\t 0xa0: 0x2000001,\n\t 0xb0: 0x2100400,\n\t 0xc0: 0x2100000,\n\t 0xd0: 0x401,\n\t 0xe0: 0x100400,\n\t 0xf0: 0x2000000,\n\t 0x8: 0x2100001,\n\t 0x18: 0x0,\n\t 0x28: 0x2000401,\n\t 0x38: 0x2100400,\n\t 0x48: 0x100000,\n\t 0x58: 0x2000001,\n\t 0x68: 0x2000000,\n\t 0x78: 0x401,\n\t 0x88: 0x100401,\n\t 0x98: 0x2000400,\n\t 0xa8: 0x2100000,\n\t 0xb8: 0x100001,\n\t 0xc8: 0x400,\n\t 0xd8: 0x2100401,\n\t 0xe8: 0x1,\n\t 0xf8: 0x100400,\n\t 0x100: 0x2000000,\n\t 0x110: 0x100000,\n\t 0x120: 0x2000401,\n\t 0x130: 0x2100001,\n\t 0x140: 0x100001,\n\t 0x150: 0x2000400,\n\t 0x160: 0x2100400,\n\t 0x170: 0x100401,\n\t 0x180: 0x401,\n\t 0x190: 0x2100401,\n\t 0x1a0: 0x100400,\n\t 0x1b0: 0x1,\n\t 0x1c0: 0x0,\n\t 0x1d0: 0x2100000,\n\t 0x1e0: 0x2000001,\n\t 0x1f0: 0x400,\n\t 0x108: 0x100400,\n\t 0x118: 0x2000401,\n\t 0x128: 0x2100001,\n\t 0x138: 0x1,\n\t 0x148: 0x2000000,\n\t 0x158: 0x100000,\n\t 0x168: 0x401,\n\t 0x178: 0x2100400,\n\t 0x188: 0x2000001,\n\t 0x198: 0x2100000,\n\t 0x1a8: 0x0,\n\t 0x1b8: 0x2100401,\n\t 0x1c8: 0x100401,\n\t 0x1d8: 0x400,\n\t 0x1e8: 0x2000400,\n\t 0x1f8: 0x100001\n\t },\n\t {\n\t 0x0: 0x8000820,\n\t 0x1: 0x20000,\n\t 0x2: 0x8000000,\n\t 0x3: 0x20,\n\t 0x4: 0x20020,\n\t 0x5: 0x8020820,\n\t 0x6: 0x8020800,\n\t 0x7: 0x800,\n\t 0x8: 0x8020000,\n\t 0x9: 0x8000800,\n\t 0xa: 0x20800,\n\t 0xb: 0x8020020,\n\t 0xc: 0x820,\n\t 0xd: 0x0,\n\t 0xe: 0x8000020,\n\t 0xf: 0x20820,\n\t 0x80000000: 0x800,\n\t 0x80000001: 0x8020820,\n\t 0x80000002: 0x8000820,\n\t 0x80000003: 0x8000000,\n\t 0x80000004: 0x8020000,\n\t 0x80000005: 0x20800,\n\t 0x80000006: 0x20820,\n\t 0x80000007: 0x20,\n\t 0x80000008: 0x8000020,\n\t 0x80000009: 0x820,\n\t 0x8000000a: 0x20020,\n\t 0x8000000b: 0x8020800,\n\t 0x8000000c: 0x0,\n\t 0x8000000d: 0x8020020,\n\t 0x8000000e: 0x8000800,\n\t 0x8000000f: 0x20000,\n\t 0x10: 0x20820,\n\t 0x11: 0x8020800,\n\t 0x12: 0x20,\n\t 0x13: 0x800,\n\t 0x14: 0x8000800,\n\t 0x15: 0x8000020,\n\t 0x16: 0x8020020,\n\t 0x17: 0x20000,\n\t 0x18: 0x0,\n\t 0x19: 0x20020,\n\t 0x1a: 0x8020000,\n\t 0x1b: 0x8000820,\n\t 0x1c: 0x8020820,\n\t 0x1d: 0x20800,\n\t 0x1e: 0x820,\n\t 0x1f: 0x8000000,\n\t 0x80000010: 0x20000,\n\t 0x80000011: 0x800,\n\t 0x80000012: 0x8020020,\n\t 0x80000013: 0x20820,\n\t 0x80000014: 0x20,\n\t 0x80000015: 0x8020000,\n\t 0x80000016: 0x8000000,\n\t 0x80000017: 0x8000820,\n\t 0x80000018: 0x8020820,\n\t 0x80000019: 0x8000020,\n\t 0x8000001a: 0x8000800,\n\t 0x8000001b: 0x0,\n\t 0x8000001c: 0x20800,\n\t 0x8000001d: 0x820,\n\t 0x8000001e: 0x20020,\n\t 0x8000001f: 0x8020800\n\t }\n\t ];\n\n\t // Masks that select the SBOX input\n\t var SBOX_MASK = [\n\t 0xf8000001, 0x1f800000, 0x01f80000, 0x001f8000,\n\t 0x0001f800, 0x00001f80, 0x000001f8, 0x8000001f\n\t ];\n\n\t /**\n\t * DES block cipher algorithm.\n\t */\n\t var DES = C_algo.DES = BlockCipher.extend({\n\t _doReset: function () {\n\t // Shortcuts\n\t var key = this._key;\n\t var keyWords = key.words;\n\n\t // Select 56 bits according to PC1\n\t var keyBits = [];\n\t for (var i = 0; i < 56; i++) {\n\t var keyBitPos = PC1[i] - 1;\n\t keyBits[i] = (keyWords[keyBitPos >>> 5] >>> (31 - keyBitPos % 32)) & 1;\n\t }\n\n\t // Assemble 16 subkeys\n\t var subKeys = this._subKeys = [];\n\t for (var nSubKey = 0; nSubKey < 16; nSubKey++) {\n\t // Create subkey\n\t var subKey = subKeys[nSubKey] = [];\n\n\t // Shortcut\n\t var bitShift = BIT_SHIFTS[nSubKey];\n\n\t // Select 48 bits according to PC2\n\t for (var i = 0; i < 24; i++) {\n\t // Select from the left 28 key bits\n\t subKey[(i / 6) | 0] |= keyBits[((PC2[i] - 1) + bitShift) % 28] << (31 - i % 6);\n\n\t // Select from the right 28 key bits\n\t subKey[4 + ((i / 6) | 0)] |= keyBits[28 + (((PC2[i + 24] - 1) + bitShift) % 28)] << (31 - i % 6);\n\t }\n\n\t // Since each subkey is applied to an expanded 32-bit input,\n\t // the subkey can be broken into 8 values scaled to 32-bits,\n\t // which allows the key to be used without expansion\n\t subKey[0] = (subKey[0] << 1) | (subKey[0] >>> 31);\n\t for (var i = 1; i < 7; i++) {\n\t subKey[i] = subKey[i] >>> ((i - 1) * 4 + 3);\n\t }\n\t subKey[7] = (subKey[7] << 5) | (subKey[7] >>> 27);\n\t }\n\n\t // Compute inverse subkeys\n\t var invSubKeys = this._invSubKeys = [];\n\t for (var i = 0; i < 16; i++) {\n\t invSubKeys[i] = subKeys[15 - i];\n\t }\n\t },\n\n\t encryptBlock: function (M, offset) {\n\t this._doCryptBlock(M, offset, this._subKeys);\n\t },\n\n\t decryptBlock: function (M, offset) {\n\t this._doCryptBlock(M, offset, this._invSubKeys);\n\t },\n\n\t _doCryptBlock: function (M, offset, subKeys) {\n\t // Get input\n\t this._lBlock = M[offset];\n\t this._rBlock = M[offset + 1];\n\n\t // Initial permutation\n\t exchangeLR.call(this, 4, 0x0f0f0f0f);\n\t exchangeLR.call(this, 16, 0x0000ffff);\n\t exchangeRL.call(this, 2, 0x33333333);\n\t exchangeRL.call(this, 8, 0x00ff00ff);\n\t exchangeLR.call(this, 1, 0x55555555);\n\n\t // Rounds\n\t for (var round = 0; round < 16; round++) {\n\t // Shortcuts\n\t var subKey = subKeys[round];\n\t var lBlock = this._lBlock;\n\t var rBlock = this._rBlock;\n\n\t // Feistel function\n\t var f = 0;\n\t for (var i = 0; i < 8; i++) {\n\t f |= SBOX_P[i][((rBlock ^ subKey[i]) & SBOX_MASK[i]) >>> 0];\n\t }\n\t this._lBlock = rBlock;\n\t this._rBlock = lBlock ^ f;\n\t }\n\n\t // Undo swap from last round\n\t var t = this._lBlock;\n\t this._lBlock = this._rBlock;\n\t this._rBlock = t;\n\n\t // Final permutation\n\t exchangeLR.call(this, 1, 0x55555555);\n\t exchangeRL.call(this, 8, 0x00ff00ff);\n\t exchangeRL.call(this, 2, 0x33333333);\n\t exchangeLR.call(this, 16, 0x0000ffff);\n\t exchangeLR.call(this, 4, 0x0f0f0f0f);\n\n\t // Set output\n\t M[offset] = this._lBlock;\n\t M[offset + 1] = this._rBlock;\n\t },\n\n\t keySize: 64/32,\n\n\t ivSize: 64/32,\n\n\t blockSize: 64/32\n\t });\n\n\t // Swap bits across the left and right words\n\t function exchangeLR(offset, mask) {\n\t var t = ((this._lBlock >>> offset) ^ this._rBlock) & mask;\n\t this._rBlock ^= t;\n\t this._lBlock ^= t << offset;\n\t }\n\n\t function exchangeRL(offset, mask) {\n\t var t = ((this._rBlock >>> offset) ^ this._lBlock) & mask;\n\t this._lBlock ^= t;\n\t this._rBlock ^= t << offset;\n\t }\n\n\t /**\n\t * Shortcut functions to the cipher's object interface.\n\t *\n\t * @example\n\t *\n\t * var ciphertext = CryptoJS.DES.encrypt(message, key, cfg);\n\t * var plaintext = CryptoJS.DES.decrypt(ciphertext, key, cfg);\n\t */\n\t C.DES = BlockCipher._createHelper(DES);\n\n\t /**\n\t * Triple-DES block cipher algorithm.\n\t */\n\t var TripleDES = C_algo.TripleDES = BlockCipher.extend({\n\t _doReset: function () {\n\t // Shortcuts\n\t var key = this._key;\n\t var keyWords = key.words;\n\t // Make sure the key length is valid (64, 128 or >= 192 bit)\n\t if (keyWords.length !== 2 && keyWords.length !== 4 && keyWords.length < 6) {\n\t throw new Error('Invalid key length - 3DES requires the key length to be 64, 128, 192 or >192.');\n\t }\n\n\t // Extend the key according to the keying options defined in 3DES standard\n\t var key1 = keyWords.slice(0, 2);\n\t var key2 = keyWords.length < 4 ? keyWords.slice(0, 2) : keyWords.slice(2, 4);\n\t var key3 = keyWords.length < 6 ? keyWords.slice(0, 2) : keyWords.slice(4, 6);\n\n\t // Create DES instances\n\t this._des1 = DES.createEncryptor(WordArray.create(key1));\n\t this._des2 = DES.createEncryptor(WordArray.create(key2));\n\t this._des3 = DES.createEncryptor(WordArray.create(key3));\n\t },\n\n\t encryptBlock: function (M, offset) {\n\t this._des1.encryptBlock(M, offset);\n\t this._des2.decryptBlock(M, offset);\n\t this._des3.encryptBlock(M, offset);\n\t },\n\n\t decryptBlock: function (M, offset) {\n\t this._des3.decryptBlock(M, offset);\n\t this._des2.encryptBlock(M, offset);\n\t this._des1.decryptBlock(M, offset);\n\t },\n\n\t keySize: 192/32,\n\n\t ivSize: 64/32,\n\n\t blockSize: 64/32\n\t });\n\n\t /**\n\t * Shortcut functions to the cipher's object interface.\n\t *\n\t * @example\n\t *\n\t * var ciphertext = CryptoJS.TripleDES.encrypt(message, key, cfg);\n\t * var plaintext = CryptoJS.TripleDES.decrypt(ciphertext, key, cfg);\n\t */\n\t C.TripleDES = BlockCipher._createHelper(TripleDES);\n\t}());\n\n\n\treturn CryptoJS.TripleDES;\n\n}));",";(function (root, factory) {\n\tif (typeof exports === \"object\") {\n\t\t// CommonJS\n\t\tmodule.exports = exports = factory(require(\"./core\"));\n\t}\n\telse if (typeof define === \"function\" && define.amd) {\n\t\t// AMD\n\t\tdefine([\"./core\"], factory);\n\t}\n\telse {\n\t\t// Global (browser)\n\t\tfactory(root.CryptoJS);\n\t}\n}(this, function (CryptoJS) {\n\n\t(function (undefined) {\n\t // Shortcuts\n\t var C = CryptoJS;\n\t var C_lib = C.lib;\n\t var Base = C_lib.Base;\n\t var X32WordArray = C_lib.WordArray;\n\n\t /**\n\t * x64 namespace.\n\t */\n\t var C_x64 = C.x64 = {};\n\n\t /**\n\t * A 64-bit word.\n\t */\n\t var X64Word = C_x64.Word = Base.extend({\n\t /**\n\t * Initializes a newly created 64-bit word.\n\t *\n\t * @param {number} high The high 32 bits.\n\t * @param {number} low The low 32 bits.\n\t *\n\t * @example\n\t *\n\t * var x64Word = CryptoJS.x64.Word.create(0x00010203, 0x04050607);\n\t */\n\t init: function (high, low) {\n\t this.high = high;\n\t this.low = low;\n\t }\n\n\t /**\n\t * Bitwise NOTs this word.\n\t *\n\t * @return {X64Word} A new x64-Word object after negating.\n\t *\n\t * @example\n\t *\n\t * var negated = x64Word.not();\n\t */\n\t // not: function () {\n\t // var high = ~this.high;\n\t // var low = ~this.low;\n\n\t // return X64Word.create(high, low);\n\t // },\n\n\t /**\n\t * Bitwise ANDs this word with the passed word.\n\t *\n\t * @param {X64Word} word The x64-Word to AND with this word.\n\t *\n\t * @return {X64Word} A new x64-Word object after ANDing.\n\t *\n\t * @example\n\t *\n\t * var anded = x64Word.and(anotherX64Word);\n\t */\n\t // and: function (word) {\n\t // var high = this.high & word.high;\n\t // var low = this.low & word.low;\n\n\t // return X64Word.create(high, low);\n\t // },\n\n\t /**\n\t * Bitwise ORs this word with the passed word.\n\t *\n\t * @param {X64Word} word The x64-Word to OR with this word.\n\t *\n\t * @return {X64Word} A new x64-Word object after ORing.\n\t *\n\t * @example\n\t *\n\t * var ored = x64Word.or(anotherX64Word);\n\t */\n\t // or: function (word) {\n\t // var high = this.high | word.high;\n\t // var low = this.low | word.low;\n\n\t // return X64Word.create(high, low);\n\t // },\n\n\t /**\n\t * Bitwise XORs this word with the passed word.\n\t *\n\t * @param {X64Word} word The x64-Word to XOR with this word.\n\t *\n\t * @return {X64Word} A new x64-Word object after XORing.\n\t *\n\t * @example\n\t *\n\t * var xored = x64Word.xor(anotherX64Word);\n\t */\n\t // xor: function (word) {\n\t // var high = this.high ^ word.high;\n\t // var low = this.low ^ word.low;\n\n\t // return X64Word.create(high, low);\n\t // },\n\n\t /**\n\t * Shifts this word n bits to the left.\n\t *\n\t * @param {number} n The number of bits to shift.\n\t *\n\t * @return {X64Word} A new x64-Word object after shifting.\n\t *\n\t * @example\n\t *\n\t * var shifted = x64Word.shiftL(25);\n\t */\n\t // shiftL: function (n) {\n\t // if (n < 32) {\n\t // var high = (this.high << n) | (this.low >>> (32 - n));\n\t // var low = this.low << n;\n\t // } else {\n\t // var high = this.low << (n - 32);\n\t // var low = 0;\n\t // }\n\n\t // return X64Word.create(high, low);\n\t // },\n\n\t /**\n\t * Shifts this word n bits to the right.\n\t *\n\t * @param {number} n The number of bits to shift.\n\t *\n\t * @return {X64Word} A new x64-Word object after shifting.\n\t *\n\t * @example\n\t *\n\t * var shifted = x64Word.shiftR(7);\n\t */\n\t // shiftR: function (n) {\n\t // if (n < 32) {\n\t // var low = (this.low >>> n) | (this.high << (32 - n));\n\t // var high = this.high >>> n;\n\t // } else {\n\t // var low = this.high >>> (n - 32);\n\t // var high = 0;\n\t // }\n\n\t // return X64Word.create(high, low);\n\t // },\n\n\t /**\n\t * Rotates this word n bits to the left.\n\t *\n\t * @param {number} n The number of bits to rotate.\n\t *\n\t * @return {X64Word} A new x64-Word object after rotating.\n\t *\n\t * @example\n\t *\n\t * var rotated = x64Word.rotL(25);\n\t */\n\t // rotL: function (n) {\n\t // return this.shiftL(n).or(this.shiftR(64 - n));\n\t // },\n\n\t /**\n\t * Rotates this word n bits to the right.\n\t *\n\t * @param {number} n The number of bits to rotate.\n\t *\n\t * @return {X64Word} A new x64-Word object after rotating.\n\t *\n\t * @example\n\t *\n\t * var rotated = x64Word.rotR(7);\n\t */\n\t // rotR: function (n) {\n\t // return this.shiftR(n).or(this.shiftL(64 - n));\n\t // },\n\n\t /**\n\t * Adds this word with the passed word.\n\t *\n\t * @param {X64Word} word The x64-Word to add with this word.\n\t *\n\t * @return {X64Word} A new x64-Word object after adding.\n\t *\n\t * @example\n\t *\n\t * var added = x64Word.add(anotherX64Word);\n\t */\n\t // add: function (word) {\n\t // var low = (this.low + word.low) | 0;\n\t // var carry = (low >>> 0) < (this.low >>> 0) ? 1 : 0;\n\t // var high = (this.high + word.high + carry) | 0;\n\n\t // return X64Word.create(high, low);\n\t // }\n\t });\n\n\t /**\n\t * An array of 64-bit words.\n\t *\n\t * @property {Array} words The array of CryptoJS.x64.Word objects.\n\t * @property {number} sigBytes The number of significant bytes in this word array.\n\t */\n\t var X64WordArray = C_x64.WordArray = Base.extend({\n\t /**\n\t * Initializes a newly created word array.\n\t *\n\t * @param {Array} words (Optional) An array of CryptoJS.x64.Word objects.\n\t * @param {number} sigBytes (Optional) The number of significant bytes in the words.\n\t *\n\t * @example\n\t *\n\t * var wordArray = CryptoJS.x64.WordArray.create();\n\t *\n\t * var wordArray = CryptoJS.x64.WordArray.create([\n\t * CryptoJS.x64.Word.create(0x00010203, 0x04050607),\n\t * CryptoJS.x64.Word.create(0x18191a1b, 0x1c1d1e1f)\n\t * ]);\n\t *\n\t * var wordArray = CryptoJS.x64.WordArray.create([\n\t * CryptoJS.x64.Word.create(0x00010203, 0x04050607),\n\t * CryptoJS.x64.Word.create(0x18191a1b, 0x1c1d1e1f)\n\t * ], 10);\n\t */\n\t init: function (words, sigBytes) {\n\t words = this.words = words || [];\n\n\t if (sigBytes != undefined) {\n\t this.sigBytes = sigBytes;\n\t } else {\n\t this.sigBytes = words.length * 8;\n\t }\n\t },\n\n\t /**\n\t * Converts this 64-bit word array to a 32-bit word array.\n\t *\n\t * @return {CryptoJS.lib.WordArray} This word array's data as a 32-bit word array.\n\t *\n\t * @example\n\t *\n\t * var x32WordArray = x64WordArray.toX32();\n\t */\n\t toX32: function () {\n\t // Shortcuts\n\t var x64Words = this.words;\n\t var x64WordsLength = x64Words.length;\n\n\t // Convert\n\t var x32Words = [];\n\t for (var i = 0; i < x64WordsLength; i++) {\n\t var x64Word = x64Words[i];\n\t x32Words.push(x64Word.high);\n\t x32Words.push(x64Word.low);\n\t }\n\n\t return X32WordArray.create(x32Words, this.sigBytes);\n\t },\n\n\t /**\n\t * Creates a copy of this word array.\n\t *\n\t * @return {X64WordArray} The clone.\n\t *\n\t * @example\n\t *\n\t * var clone = x64WordArray.clone();\n\t */\n\t clone: function () {\n\t var clone = Base.clone.call(this);\n\n\t // Clone \"words\" array\n\t var words = clone.words = this.words.slice(0);\n\n\t // Clone each X64Word object\n\t var wordsLength = words.length;\n\t for (var i = 0; i < wordsLength; i++) {\n\t words[i] = words[i].clone();\n\t }\n\n\t return clone;\n\t }\n\t });\n\t}());\n\n\n\treturn CryptoJS;\n\n}));","'use strict';\n\n/******************************************************************************\n * Created 2008-08-19.\n *\n * Dijkstra path-finding functions. Adapted from the Dijkstar Python project.\n *\n * Copyright (C) 2008\n * Wyatt Baldwin \n * All rights reserved\n *\n * Licensed under the MIT license.\n *\n * http://www.opensource.org/licenses/mit-license.php\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n * THE SOFTWARE.\n *****************************************************************************/\nvar dijkstra = {\n single_source_shortest_paths: function(graph, s, d) {\n // Predecessor map for each node that has been encountered.\n // node ID => predecessor node ID\n var predecessors = {};\n\n // Costs of shortest paths from s to all nodes encountered.\n // node ID => cost\n var costs = {};\n costs[s] = 0;\n\n // Costs of shortest paths from s to all nodes encountered; differs from\n // `costs` in that it provides easy access to the node that currently has\n // the known shortest path from s.\n // XXX: Do we actually need both `costs` and `open`?\n var open = dijkstra.PriorityQueue.make();\n open.push(s, 0);\n\n var closest,\n u, v,\n cost_of_s_to_u,\n adjacent_nodes,\n cost_of_e,\n cost_of_s_to_u_plus_cost_of_e,\n cost_of_s_to_v,\n first_visit;\n while (!open.empty()) {\n // In the nodes remaining in graph that have a known cost from s,\n // find the node, u, that currently has the shortest path from s.\n closest = open.pop();\n u = closest.value;\n cost_of_s_to_u = closest.cost;\n\n // Get nodes adjacent to u...\n adjacent_nodes = graph[u] || {};\n\n // ...and explore the edges that connect u to those nodes, updating\n // the cost of the shortest paths to any or all of those nodes as\n // necessary. v is the node across the current edge from u.\n for (v in adjacent_nodes) {\n if (adjacent_nodes.hasOwnProperty(v)) {\n // Get the cost of the edge running from u to v.\n cost_of_e = adjacent_nodes[v];\n\n // Cost of s to u plus the cost of u to v across e--this is *a*\n // cost from s to v that may or may not be less than the current\n // known cost to v.\n cost_of_s_to_u_plus_cost_of_e = cost_of_s_to_u + cost_of_e;\n\n // If we haven't visited v yet OR if the current known cost from s to\n // v is greater than the new cost we just found (cost of s to u plus\n // cost of u to v across e), update v's cost in the cost list and\n // update v's predecessor in the predecessor list (it's now u).\n cost_of_s_to_v = costs[v];\n first_visit = (typeof costs[v] === 'undefined');\n if (first_visit || cost_of_s_to_v > cost_of_s_to_u_plus_cost_of_e) {\n costs[v] = cost_of_s_to_u_plus_cost_of_e;\n open.push(v, cost_of_s_to_u_plus_cost_of_e);\n predecessors[v] = u;\n }\n }\n }\n }\n\n if (typeof d !== 'undefined' && typeof costs[d] === 'undefined') {\n var msg = ['Could not find a path from ', s, ' to ', d, '.'].join('');\n throw new Error(msg);\n }\n\n return predecessors;\n },\n\n extract_shortest_path_from_predecessor_list: function(predecessors, d) {\n var nodes = [];\n var u = d;\n var predecessor;\n while (u) {\n nodes.push(u);\n predecessor = predecessors[u];\n u = predecessors[u];\n }\n nodes.reverse();\n return nodes;\n },\n\n find_path: function(graph, s, d) {\n var predecessors = dijkstra.single_source_shortest_paths(graph, s, d);\n return dijkstra.extract_shortest_path_from_predecessor_list(\n predecessors, d);\n },\n\n /**\n * A very naive priority queue implementation.\n */\n PriorityQueue: {\n make: function (opts) {\n var T = dijkstra.PriorityQueue,\n t = {},\n key;\n opts = opts || {};\n for (key in T) {\n if (T.hasOwnProperty(key)) {\n t[key] = T[key];\n }\n }\n t.queue = [];\n t.sorter = opts.sorter || T.default_sorter;\n return t;\n },\n\n default_sorter: function (a, b) {\n return a.cost - b.cost;\n },\n\n /**\n * Add a new item to the queue and ensure the highest priority element\n * is at the front of the queue.\n */\n push: function (value, cost) {\n var item = {value: value, cost: cost};\n this.queue.push(item);\n this.queue.sort(this.sorter);\n },\n\n /**\n * Return the highest priority element in the queue.\n */\n pop: function () {\n return this.queue.shift();\n },\n\n empty: function () {\n return this.queue.length === 0;\n }\n }\n};\n\n\n// node.js module exports\nif (typeof module !== 'undefined') {\n module.exports = dijkstra;\n}\n","// Copyright (c) 2013 Pieroxy \n// This work is free. You can redistribute it and/or modify it\n// under the terms of the WTFPL, Version 2\n// For more information see LICENSE.txt or http://www.wtfpl.net/\n//\n// For more information, the home page:\n// http://pieroxy.net/blog/pages/lz-string/testing.html\n//\n// LZ-based compression algorithm, version 1.4.5\nvar LZString = (function() {\n\n// private property\nvar f = String.fromCharCode;\nvar keyStrBase64 = \"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=\";\nvar keyStrUriSafe = \"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+-$\";\nvar baseReverseDic = {};\n\nfunction getBaseValue(alphabet, character) {\n if (!baseReverseDic[alphabet]) {\n baseReverseDic[alphabet] = {};\n for (var i=0 ; i>> 8;\n buf[i*2+1] = current_value % 256;\n }\n return buf;\n },\n\n //decompress from uint8array (UCS-2 big endian format)\n decompressFromUint8Array:function (compressed) {\n if (compressed===null || compressed===undefined){\n return LZString.decompress(compressed);\n } else {\n var buf=new Array(compressed.length/2); // 2 bytes per character\n for (var i=0, TotalLen=buf.length; i> 1;\n }\n } else {\n value = 1;\n for (i=0 ; i> 1;\n }\n }\n context_enlargeIn--;\n if (context_enlargeIn == 0) {\n context_enlargeIn = Math.pow(2, context_numBits);\n context_numBits++;\n }\n delete context_dictionaryToCreate[context_w];\n } else {\n value = context_dictionary[context_w];\n for (i=0 ; i> 1;\n }\n\n\n }\n context_enlargeIn--;\n if (context_enlargeIn == 0) {\n context_enlargeIn = Math.pow(2, context_numBits);\n context_numBits++;\n }\n // Add wc to the dictionary.\n context_dictionary[context_wc] = context_dictSize++;\n context_w = String(context_c);\n }\n }\n\n // Output the code for w.\n if (context_w !== \"\") {\n if (Object.prototype.hasOwnProperty.call(context_dictionaryToCreate,context_w)) {\n if (context_w.charCodeAt(0)<256) {\n for (i=0 ; i> 1;\n }\n } else {\n value = 1;\n for (i=0 ; i> 1;\n }\n }\n context_enlargeIn--;\n if (context_enlargeIn == 0) {\n context_enlargeIn = Math.pow(2, context_numBits);\n context_numBits++;\n }\n delete context_dictionaryToCreate[context_w];\n } else {\n value = context_dictionary[context_w];\n for (i=0 ; i> 1;\n }\n\n\n }\n context_enlargeIn--;\n if (context_enlargeIn == 0) {\n context_enlargeIn = Math.pow(2, context_numBits);\n context_numBits++;\n }\n }\n\n // Mark the end of the stream\n value = 2;\n for (i=0 ; i> 1;\n }\n\n // Flush the last char\n while (true) {\n context_data_val = (context_data_val << 1);\n if (context_data_position == bitsPerChar-1) {\n context_data.push(getCharFromInt(context_data_val));\n break;\n }\n else context_data_position++;\n }\n return context_data.join('');\n },\n\n decompress: function (compressed) {\n if (compressed == null) return \"\";\n if (compressed == \"\") return null;\n return LZString._decompress(compressed.length, 32768, function(index) { return compressed.charCodeAt(index); });\n },\n\n _decompress: function (length, resetValue, getNextValue) {\n var dictionary = [],\n next,\n enlargeIn = 4,\n dictSize = 4,\n numBits = 3,\n entry = \"\",\n result = [],\n i,\n w,\n bits, resb, maxpower, power,\n c,\n data = {val:getNextValue(0), position:resetValue, index:1};\n\n for (i = 0; i < 3; i += 1) {\n dictionary[i] = i;\n }\n\n bits = 0;\n maxpower = Math.pow(2,2);\n power=1;\n while (power!=maxpower) {\n resb = data.val & data.position;\n data.position >>= 1;\n if (data.position == 0) {\n data.position = resetValue;\n data.val = getNextValue(data.index++);\n }\n bits |= (resb>0 ? 1 : 0) * power;\n power <<= 1;\n }\n\n switch (next = bits) {\n case 0:\n bits = 0;\n maxpower = Math.pow(2,8);\n power=1;\n while (power!=maxpower) {\n resb = data.val & data.position;\n data.position >>= 1;\n if (data.position == 0) {\n data.position = resetValue;\n data.val = getNextValue(data.index++);\n }\n bits |= (resb>0 ? 1 : 0) * power;\n power <<= 1;\n }\n c = f(bits);\n break;\n case 1:\n bits = 0;\n maxpower = Math.pow(2,16);\n power=1;\n while (power!=maxpower) {\n resb = data.val & data.position;\n data.position >>= 1;\n if (data.position == 0) {\n data.position = resetValue;\n data.val = getNextValue(data.index++);\n }\n bits |= (resb>0 ? 1 : 0) * power;\n power <<= 1;\n }\n c = f(bits);\n break;\n case 2:\n return \"\";\n }\n dictionary[3] = c;\n w = c;\n result.push(c);\n while (true) {\n if (data.index > length) {\n return \"\";\n }\n\n bits = 0;\n maxpower = Math.pow(2,numBits);\n power=1;\n while (power!=maxpower) {\n resb = data.val & data.position;\n data.position >>= 1;\n if (data.position == 0) {\n data.position = resetValue;\n data.val = getNextValue(data.index++);\n }\n bits |= (resb>0 ? 1 : 0) * power;\n power <<= 1;\n }\n\n switch (c = bits) {\n case 0:\n bits = 0;\n maxpower = Math.pow(2,8);\n power=1;\n while (power!=maxpower) {\n resb = data.val & data.position;\n data.position >>= 1;\n if (data.position == 0) {\n data.position = resetValue;\n data.val = getNextValue(data.index++);\n }\n bits |= (resb>0 ? 1 : 0) * power;\n power <<= 1;\n }\n\n dictionary[dictSize++] = f(bits);\n c = dictSize-1;\n enlargeIn--;\n break;\n case 1:\n bits = 0;\n maxpower = Math.pow(2,16);\n power=1;\n while (power!=maxpower) {\n resb = data.val & data.position;\n data.position >>= 1;\n if (data.position == 0) {\n data.position = resetValue;\n data.val = getNextValue(data.index++);\n }\n bits |= (resb>0 ? 1 : 0) * power;\n power <<= 1;\n }\n dictionary[dictSize++] = f(bits);\n c = dictSize-1;\n enlargeIn--;\n break;\n case 2:\n return result.join('');\n }\n\n if (enlargeIn == 0) {\n enlargeIn = Math.pow(2, numBits);\n numBits++;\n }\n\n if (dictionary[c]) {\n entry = dictionary[c];\n } else {\n if (c === dictSize) {\n entry = w + w.charAt(0);\n } else {\n return null;\n }\n }\n result.push(entry);\n\n // Add w+entry[0] to the dictionary.\n dictionary[dictSize++] = w + entry.charAt(0);\n enlargeIn--;\n\n w = entry;\n\n if (enlargeIn == 0) {\n enlargeIn = Math.pow(2, numBits);\n numBits++;\n }\n\n }\n }\n};\n return LZString;\n})();\n\nif (typeof define === 'function' && define.amd) {\n define(function () { return LZString; });\n} else if( typeof module !== 'undefined' && module != null ) {\n module.exports = LZString\n} else if( typeof angular !== 'undefined' && angular != null ) {\n angular.module('LZString', [])\n .factory('LZString', function () {\n return LZString;\n });\n}\n","/**\n * Copyright (c) 2013-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n'use strict';\n\nvar ReactPropTypesSecret = require('./lib/ReactPropTypesSecret');\n\nfunction emptyFunction() {}\nfunction emptyFunctionWithReset() {}\nemptyFunctionWithReset.resetWarningCache = emptyFunction;\n\nmodule.exports = function() {\n function shim(props, propName, componentName, location, propFullName, secret) {\n if (secret === ReactPropTypesSecret) {\n // It is still safe when called from React.\n return;\n }\n var err = new Error(\n 'Calling PropTypes validators directly is not supported by the `prop-types` package. ' +\n 'Use PropTypes.checkPropTypes() to call them. ' +\n 'Read more at http://fb.me/use-check-prop-types'\n );\n err.name = 'Invariant Violation';\n throw err;\n };\n shim.isRequired = shim;\n function getShim() {\n return shim;\n };\n // Important!\n // Keep this list in sync with production version in `./factoryWithTypeCheckers.js`.\n var ReactPropTypes = {\n array: shim,\n bigint: shim,\n bool: shim,\n func: shim,\n number: shim,\n object: shim,\n string: shim,\n symbol: shim,\n\n any: shim,\n arrayOf: getShim,\n element: shim,\n elementType: shim,\n instanceOf: getShim,\n node: shim,\n objectOf: getShim,\n oneOf: getShim,\n oneOfType: getShim,\n shape: getShim,\n exact: getShim,\n\n checkPropTypes: emptyFunctionWithReset,\n resetWarningCache: emptyFunction\n };\n\n ReactPropTypes.PropTypes = ReactPropTypes;\n\n return ReactPropTypes;\n};\n","/**\n * Copyright (c) 2013-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\nif (process.env.NODE_ENV !== 'production') {\n var ReactIs = require('react-is');\n\n // By explicitly using `prop-types` you are opting into new development behavior.\n // http://fb.me/prop-types-in-prod\n var throwOnDirectAccess = true;\n module.exports = require('./factoryWithTypeCheckers')(ReactIs.isElement, throwOnDirectAccess);\n} else {\n // By explicitly using `prop-types` you are opting into new production behavior.\n // http://fb.me/prop-types-in-prod\n module.exports = require('./factoryWithThrowingShims')();\n}\n","/**\n * Copyright (c) 2013-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n'use strict';\n\nvar ReactPropTypesSecret = 'SECRET_DO_NOT_PASS_THIS_OR_YOU_WILL_BE_FIRED';\n\nmodule.exports = ReactPropTypesSecret;\n","\nconst canPromise = require('./can-promise')\n\nconst QRCode = require('./core/qrcode')\nconst CanvasRenderer = require('./renderer/canvas')\nconst SvgRenderer = require('./renderer/svg-tag.js')\n\nfunction renderCanvas (renderFunc, canvas, text, opts, cb) {\n const args = [].slice.call(arguments, 1)\n const argsNum = args.length\n const isLastArgCb = typeof args[argsNum - 1] === 'function'\n\n if (!isLastArgCb && !canPromise()) {\n throw new Error('Callback required as last argument')\n }\n\n if (isLastArgCb) {\n if (argsNum < 2) {\n throw new Error('Too few arguments provided')\n }\n\n if (argsNum === 2) {\n cb = text\n text = canvas\n canvas = opts = undefined\n } else if (argsNum === 3) {\n if (canvas.getContext && typeof cb === 'undefined') {\n cb = opts\n opts = undefined\n } else {\n cb = opts\n opts = text\n text = canvas\n canvas = undefined\n }\n }\n } else {\n if (argsNum < 1) {\n throw new Error('Too few arguments provided')\n }\n\n if (argsNum === 1) {\n text = canvas\n canvas = opts = undefined\n } else if (argsNum === 2 && !canvas.getContext) {\n opts = text\n text = canvas\n canvas = undefined\n }\n\n return new Promise(function (resolve, reject) {\n try {\n const data = QRCode.create(text, opts)\n resolve(renderFunc(data, canvas, opts))\n } catch (e) {\n reject(e)\n }\n })\n }\n\n try {\n const data = QRCode.create(text, opts)\n cb(null, renderFunc(data, canvas, opts))\n } catch (e) {\n cb(e)\n }\n}\n\nexports.create = QRCode.create\nexports.toCanvas = renderCanvas.bind(null, CanvasRenderer.render)\nexports.toDataURL = renderCanvas.bind(null, CanvasRenderer.renderToDataURL)\n\n// only svg for now.\nexports.toString = renderCanvas.bind(null, function (data, _, opts) {\n return SvgRenderer.render(data, opts)\n})\n","// can-promise has a crash in some versions of react native that dont have\n// standard global objects\n// https://github.com/soldair/node-qrcode/issues/157\n\nmodule.exports = function () {\n return typeof Promise === 'function' && Promise.prototype && Promise.prototype.then\n}\n","/**\n * Alignment pattern are fixed reference pattern in defined positions\n * in a matrix symbology, which enables the decode software to re-synchronise\n * the coordinate mapping of the image modules in the event of moderate amounts\n * of distortion of the image.\n *\n * Alignment patterns are present only in QR Code symbols of version 2 or larger\n * and their number depends on the symbol version.\n */\n\nconst getSymbolSize = require('./utils').getSymbolSize\n\n/**\n * Calculate the row/column coordinates of the center module of each alignment pattern\n * for the specified QR Code version.\n *\n * The alignment patterns are positioned symmetrically on either side of the diagonal\n * running from the top left corner of the symbol to the bottom right corner.\n *\n * Since positions are simmetrical only half of the coordinates are returned.\n * Each item of the array will represent in turn the x and y coordinate.\n * @see {@link getPositions}\n *\n * @param {Number} version QR Code version\n * @return {Array} Array of coordinate\n */\nexports.getRowColCoords = function getRowColCoords (version) {\n if (version === 1) return []\n\n const posCount = Math.floor(version / 7) + 2\n const size = getSymbolSize(version)\n const intervals = size === 145 ? 26 : Math.ceil((size - 13) / (2 * posCount - 2)) * 2\n const positions = [size - 7] // Last coord is always (size - 7)\n\n for (let i = 1; i < posCount - 1; i++) {\n positions[i] = positions[i - 1] - intervals\n }\n\n positions.push(6) // First coord is always 6\n\n return positions.reverse()\n}\n\n/**\n * Returns an array containing the positions of each alignment pattern.\n * Each array's element represent the center point of the pattern as (x, y) coordinates\n *\n * Coordinates are calculated expanding the row/column coordinates returned by {@link getRowColCoords}\n * and filtering out the items that overlaps with finder pattern\n *\n * @example\n * For a Version 7 symbol {@link getRowColCoords} returns values 6, 22 and 38.\n * The alignment patterns, therefore, are to be centered on (row, column)\n * positions (6,22), (22,6), (22,22), (22,38), (38,22), (38,38).\n * Note that the coordinates (6,6), (6,38), (38,6) are occupied by finder patterns\n * and are not therefore used for alignment patterns.\n *\n * let pos = getPositions(7)\n * // [[6,22], [22,6], [22,22], [22,38], [38,22], [38,38]]\n *\n * @param {Number} version QR Code version\n * @return {Array} Array of coordinates\n */\nexports.getPositions = function getPositions (version) {\n const coords = []\n const pos = exports.getRowColCoords(version)\n const posLength = pos.length\n\n for (let i = 0; i < posLength; i++) {\n for (let j = 0; j < posLength; j++) {\n // Skip if position is occupied by finder patterns\n if ((i === 0 && j === 0) || // top-left\n (i === 0 && j === posLength - 1) || // bottom-left\n (i === posLength - 1 && j === 0)) { // top-right\n continue\n }\n\n coords.push([pos[i], pos[j]])\n }\n }\n\n return coords\n}\n","const Mode = require('./mode')\n\n/**\n * Array of characters available in alphanumeric mode\n *\n * As per QR Code specification, to each character\n * is assigned a value from 0 to 44 which in this case coincides\n * with the array index\n *\n * @type {Array}\n */\nconst ALPHA_NUM_CHARS = [\n '0', '1', '2', '3', '4', '5', '6', '7', '8', '9',\n 'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M',\n 'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z',\n ' ', '$', '%', '*', '+', '-', '.', '/', ':'\n]\n\nfunction AlphanumericData (data) {\n this.mode = Mode.ALPHANUMERIC\n this.data = data\n}\n\nAlphanumericData.getBitsLength = function getBitsLength (length) {\n return 11 * Math.floor(length / 2) + 6 * (length % 2)\n}\n\nAlphanumericData.prototype.getLength = function getLength () {\n return this.data.length\n}\n\nAlphanumericData.prototype.getBitsLength = function getBitsLength () {\n return AlphanumericData.getBitsLength(this.data.length)\n}\n\nAlphanumericData.prototype.write = function write (bitBuffer) {\n let i\n\n // Input data characters are divided into groups of two characters\n // and encoded as 11-bit binary codes.\n for (i = 0; i + 2 <= this.data.length; i += 2) {\n // The character value of the first character is multiplied by 45\n let value = ALPHA_NUM_CHARS.indexOf(this.data[i]) * 45\n\n // The character value of the second digit is added to the product\n value += ALPHA_NUM_CHARS.indexOf(this.data[i + 1])\n\n // The sum is then stored as 11-bit binary number\n bitBuffer.put(value, 11)\n }\n\n // If the number of input data characters is not a multiple of two,\n // the character value of the final character is encoded as a 6-bit binary number.\n if (this.data.length % 2) {\n bitBuffer.put(ALPHA_NUM_CHARS.indexOf(this.data[i]), 6)\n }\n}\n\nmodule.exports = AlphanumericData\n","function BitBuffer () {\n this.buffer = []\n this.length = 0\n}\n\nBitBuffer.prototype = {\n\n get: function (index) {\n const bufIndex = Math.floor(index / 8)\n return ((this.buffer[bufIndex] >>> (7 - index % 8)) & 1) === 1\n },\n\n put: function (num, length) {\n for (let i = 0; i < length; i++) {\n this.putBit(((num >>> (length - i - 1)) & 1) === 1)\n }\n },\n\n getLengthInBits: function () {\n return this.length\n },\n\n putBit: function (bit) {\n const bufIndex = Math.floor(this.length / 8)\n if (this.buffer.length <= bufIndex) {\n this.buffer.push(0)\n }\n\n if (bit) {\n this.buffer[bufIndex] |= (0x80 >>> (this.length % 8))\n }\n\n this.length++\n }\n}\n\nmodule.exports = BitBuffer\n","/**\n * Helper class to handle QR Code symbol modules\n *\n * @param {Number} size Symbol size\n */\nfunction BitMatrix (size) {\n if (!size || size < 1) {\n throw new Error('BitMatrix size must be defined and greater than 0')\n }\n\n this.size = size\n this.data = new Uint8Array(size * size)\n this.reservedBit = new Uint8Array(size * size)\n}\n\n/**\n * Set bit value at specified location\n * If reserved flag is set, this bit will be ignored during masking process\n *\n * @param {Number} row\n * @param {Number} col\n * @param {Boolean} value\n * @param {Boolean} reserved\n */\nBitMatrix.prototype.set = function (row, col, value, reserved) {\n const index = row * this.size + col\n this.data[index] = value\n if (reserved) this.reservedBit[index] = true\n}\n\n/**\n * Returns bit value at specified location\n *\n * @param {Number} row\n * @param {Number} col\n * @return {Boolean}\n */\nBitMatrix.prototype.get = function (row, col) {\n return this.data[row * this.size + col]\n}\n\n/**\n * Applies xor operator at specified location\n * (used during masking process)\n *\n * @param {Number} row\n * @param {Number} col\n * @param {Boolean} value\n */\nBitMatrix.prototype.xor = function (row, col, value) {\n this.data[row * this.size + col] ^= value\n}\n\n/**\n * Check if bit at specified location is reserved\n *\n * @param {Number} row\n * @param {Number} col\n * @return {Boolean}\n */\nBitMatrix.prototype.isReserved = function (row, col) {\n return this.reservedBit[row * this.size + col]\n}\n\nmodule.exports = BitMatrix\n","const Mode = require('./mode')\n\nfunction ByteData (data) {\n this.mode = Mode.BYTE\n if (typeof (data) === 'string') {\n this.data = new TextEncoder().encode(data)\n } else {\n this.data = new Uint8Array(data)\n }\n}\n\nByteData.getBitsLength = function getBitsLength (length) {\n return length * 8\n}\n\nByteData.prototype.getLength = function getLength () {\n return this.data.length\n}\n\nByteData.prototype.getBitsLength = function getBitsLength () {\n return ByteData.getBitsLength(this.data.length)\n}\n\nByteData.prototype.write = function (bitBuffer) {\n for (let i = 0, l = this.data.length; i < l; i++) {\n bitBuffer.put(this.data[i], 8)\n }\n}\n\nmodule.exports = ByteData\n","const ECLevel = require('./error-correction-level')\r\n\r\nconst EC_BLOCKS_TABLE = [\r\n// L M Q H\r\n 1, 1, 1, 1,\r\n 1, 1, 1, 1,\r\n 1, 1, 2, 2,\r\n 1, 2, 2, 4,\r\n 1, 2, 4, 4,\r\n 2, 4, 4, 4,\r\n 2, 4, 6, 5,\r\n 2, 4, 6, 6,\r\n 2, 5, 8, 8,\r\n 4, 5, 8, 8,\r\n 4, 5, 8, 11,\r\n 4, 8, 10, 11,\r\n 4, 9, 12, 16,\r\n 4, 9, 16, 16,\r\n 6, 10, 12, 18,\r\n 6, 10, 17, 16,\r\n 6, 11, 16, 19,\r\n 6, 13, 18, 21,\r\n 7, 14, 21, 25,\r\n 8, 16, 20, 25,\r\n 8, 17, 23, 25,\r\n 9, 17, 23, 34,\r\n 9, 18, 25, 30,\r\n 10, 20, 27, 32,\r\n 12, 21, 29, 35,\r\n 12, 23, 34, 37,\r\n 12, 25, 34, 40,\r\n 13, 26, 35, 42,\r\n 14, 28, 38, 45,\r\n 15, 29, 40, 48,\r\n 16, 31, 43, 51,\r\n 17, 33, 45, 54,\r\n 18, 35, 48, 57,\r\n 19, 37, 51, 60,\r\n 19, 38, 53, 63,\r\n 20, 40, 56, 66,\r\n 21, 43, 59, 70,\r\n 22, 45, 62, 74,\r\n 24, 47, 65, 77,\r\n 25, 49, 68, 81\r\n]\r\n\r\nconst EC_CODEWORDS_TABLE = [\r\n// L M Q H\r\n 7, 10, 13, 17,\r\n 10, 16, 22, 28,\r\n 15, 26, 36, 44,\r\n 20, 36, 52, 64,\r\n 26, 48, 72, 88,\r\n 36, 64, 96, 112,\r\n 40, 72, 108, 130,\r\n 48, 88, 132, 156,\r\n 60, 110, 160, 192,\r\n 72, 130, 192, 224,\r\n 80, 150, 224, 264,\r\n 96, 176, 260, 308,\r\n 104, 198, 288, 352,\r\n 120, 216, 320, 384,\r\n 132, 240, 360, 432,\r\n 144, 280, 408, 480,\r\n 168, 308, 448, 532,\r\n 180, 338, 504, 588,\r\n 196, 364, 546, 650,\r\n 224, 416, 600, 700,\r\n 224, 442, 644, 750,\r\n 252, 476, 690, 816,\r\n 270, 504, 750, 900,\r\n 300, 560, 810, 960,\r\n 312, 588, 870, 1050,\r\n 336, 644, 952, 1110,\r\n 360, 700, 1020, 1200,\r\n 390, 728, 1050, 1260,\r\n 420, 784, 1140, 1350,\r\n 450, 812, 1200, 1440,\r\n 480, 868, 1290, 1530,\r\n 510, 924, 1350, 1620,\r\n 540, 980, 1440, 1710,\r\n 570, 1036, 1530, 1800,\r\n 570, 1064, 1590, 1890,\r\n 600, 1120, 1680, 1980,\r\n 630, 1204, 1770, 2100,\r\n 660, 1260, 1860, 2220,\r\n 720, 1316, 1950, 2310,\r\n 750, 1372, 2040, 2430\r\n]\r\n\r\n/**\r\n * Returns the number of error correction block that the QR Code should contain\r\n * for the specified version and error correction level.\r\n *\r\n * @param {Number} version QR Code version\r\n * @param {Number} errorCorrectionLevel Error correction level\r\n * @return {Number} Number of error correction blocks\r\n */\r\nexports.getBlocksCount = function getBlocksCount (version, errorCorrectionLevel) {\r\n switch (errorCorrectionLevel) {\r\n case ECLevel.L:\r\n return EC_BLOCKS_TABLE[(version - 1) * 4 + 0]\r\n case ECLevel.M:\r\n return EC_BLOCKS_TABLE[(version - 1) * 4 + 1]\r\n case ECLevel.Q:\r\n return EC_BLOCKS_TABLE[(version - 1) * 4 + 2]\r\n case ECLevel.H:\r\n return EC_BLOCKS_TABLE[(version - 1) * 4 + 3]\r\n default:\r\n return undefined\r\n }\r\n}\r\n\r\n/**\r\n * Returns the number of error correction codewords to use for the specified\r\n * version and error correction level.\r\n *\r\n * @param {Number} version QR Code version\r\n * @param {Number} errorCorrectionLevel Error correction level\r\n * @return {Number} Number of error correction codewords\r\n */\r\nexports.getTotalCodewordsCount = function getTotalCodewordsCount (version, errorCorrectionLevel) {\r\n switch (errorCorrectionLevel) {\r\n case ECLevel.L:\r\n return EC_CODEWORDS_TABLE[(version - 1) * 4 + 0]\r\n case ECLevel.M:\r\n return EC_CODEWORDS_TABLE[(version - 1) * 4 + 1]\r\n case ECLevel.Q:\r\n return EC_CODEWORDS_TABLE[(version - 1) * 4 + 2]\r\n case ECLevel.H:\r\n return EC_CODEWORDS_TABLE[(version - 1) * 4 + 3]\r\n default:\r\n return undefined\r\n }\r\n}\r\n","exports.L = { bit: 1 }\nexports.M = { bit: 0 }\nexports.Q = { bit: 3 }\nexports.H = { bit: 2 }\n\nfunction fromString (string) {\n if (typeof string !== 'string') {\n throw new Error('Param is not a string')\n }\n\n const lcStr = string.toLowerCase()\n\n switch (lcStr) {\n case 'l':\n case 'low':\n return exports.L\n\n case 'm':\n case 'medium':\n return exports.M\n\n case 'q':\n case 'quartile':\n return exports.Q\n\n case 'h':\n case 'high':\n return exports.H\n\n default:\n throw new Error('Unknown EC Level: ' + string)\n }\n}\n\nexports.isValid = function isValid (level) {\n return level && typeof level.bit !== 'undefined' &&\n level.bit >= 0 && level.bit < 4\n}\n\nexports.from = function from (value, defaultValue) {\n if (exports.isValid(value)) {\n return value\n }\n\n try {\n return fromString(value)\n } catch (e) {\n return defaultValue\n }\n}\n","const getSymbolSize = require('./utils').getSymbolSize\nconst FINDER_PATTERN_SIZE = 7\n\n/**\n * Returns an array containing the positions of each finder pattern.\n * Each array's element represent the top-left point of the pattern as (x, y) coordinates\n *\n * @param {Number} version QR Code version\n * @return {Array} Array of coordinates\n */\nexports.getPositions = function getPositions (version) {\n const size = getSymbolSize(version)\n\n return [\n // top-left\n [0, 0],\n // top-right\n [size - FINDER_PATTERN_SIZE, 0],\n // bottom-left\n [0, size - FINDER_PATTERN_SIZE]\n ]\n}\n","const Utils = require('./utils')\n\nconst G15 = (1 << 10) | (1 << 8) | (1 << 5) | (1 << 4) | (1 << 2) | (1 << 1) | (1 << 0)\nconst G15_MASK = (1 << 14) | (1 << 12) | (1 << 10) | (1 << 4) | (1 << 1)\nconst G15_BCH = Utils.getBCHDigit(G15)\n\n/**\n * Returns format information with relative error correction bits\n *\n * The format information is a 15-bit sequence containing 5 data bits,\n * with 10 error correction bits calculated using the (15, 5) BCH code.\n *\n * @param {Number} errorCorrectionLevel Error correction level\n * @param {Number} mask Mask pattern\n * @return {Number} Encoded format information bits\n */\nexports.getEncodedBits = function getEncodedBits (errorCorrectionLevel, mask) {\n const data = ((errorCorrectionLevel.bit << 3) | mask)\n let d = data << 10\n\n while (Utils.getBCHDigit(d) - G15_BCH >= 0) {\n d ^= (G15 << (Utils.getBCHDigit(d) - G15_BCH))\n }\n\n // xor final data with mask pattern in order to ensure that\n // no combination of Error Correction Level and data mask pattern\n // will result in an all-zero data string\n return ((data << 10) | d) ^ G15_MASK\n}\n","const EXP_TABLE = new Uint8Array(512)\nconst LOG_TABLE = new Uint8Array(256)\n/**\n * Precompute the log and anti-log tables for faster computation later\n *\n * For each possible value in the galois field 2^8, we will pre-compute\n * the logarithm and anti-logarithm (exponential) of this value\n *\n * ref {@link https://en.wikiversity.org/wiki/Reed%E2%80%93Solomon_codes_for_coders#Introduction_to_mathematical_fields}\n */\n;(function initTables () {\n let x = 1\n for (let i = 0; i < 255; i++) {\n EXP_TABLE[i] = x\n LOG_TABLE[x] = i\n\n x <<= 1 // multiply by 2\n\n // The QR code specification says to use byte-wise modulo 100011101 arithmetic.\n // This means that when a number is 256 or larger, it should be XORed with 0x11D.\n if (x & 0x100) { // similar to x >= 256, but a lot faster (because 0x100 == 256)\n x ^= 0x11D\n }\n }\n\n // Optimization: double the size of the anti-log table so that we don't need to mod 255 to\n // stay inside the bounds (because we will mainly use this table for the multiplication of\n // two GF numbers, no more).\n // @see {@link mul}\n for (let i = 255; i < 512; i++) {\n EXP_TABLE[i] = EXP_TABLE[i - 255]\n }\n}())\n\n/**\n * Returns log value of n inside Galois Field\n *\n * @param {Number} n\n * @return {Number}\n */\nexports.log = function log (n) {\n if (n < 1) throw new Error('log(' + n + ')')\n return LOG_TABLE[n]\n}\n\n/**\n * Returns anti-log value of n inside Galois Field\n *\n * @param {Number} n\n * @return {Number}\n */\nexports.exp = function exp (n) {\n return EXP_TABLE[n]\n}\n\n/**\n * Multiplies two number inside Galois Field\n *\n * @param {Number} x\n * @param {Number} y\n * @return {Number}\n */\nexports.mul = function mul (x, y) {\n if (x === 0 || y === 0) return 0\n\n // should be EXP_TABLE[(LOG_TABLE[x] + LOG_TABLE[y]) % 255] if EXP_TABLE wasn't oversized\n // @see {@link initTables}\n return EXP_TABLE[LOG_TABLE[x] + LOG_TABLE[y]]\n}\n","const Mode = require('./mode')\nconst Utils = require('./utils')\n\nfunction KanjiData (data) {\n this.mode = Mode.KANJI\n this.data = data\n}\n\nKanjiData.getBitsLength = function getBitsLength (length) {\n return length * 13\n}\n\nKanjiData.prototype.getLength = function getLength () {\n return this.data.length\n}\n\nKanjiData.prototype.getBitsLength = function getBitsLength () {\n return KanjiData.getBitsLength(this.data.length)\n}\n\nKanjiData.prototype.write = function (bitBuffer) {\n let i\n\n // In the Shift JIS system, Kanji characters are represented by a two byte combination.\n // These byte values are shifted from the JIS X 0208 values.\n // JIS X 0208 gives details of the shift coded representation.\n for (i = 0; i < this.data.length; i++) {\n let value = Utils.toSJIS(this.data[i])\n\n // For characters with Shift JIS values from 0x8140 to 0x9FFC:\n if (value >= 0x8140 && value <= 0x9FFC) {\n // Subtract 0x8140 from Shift JIS value\n value -= 0x8140\n\n // For characters with Shift JIS values from 0xE040 to 0xEBBF\n } else if (value >= 0xE040 && value <= 0xEBBF) {\n // Subtract 0xC140 from Shift JIS value\n value -= 0xC140\n } else {\n throw new Error(\n 'Invalid SJIS character: ' + this.data[i] + '\\n' +\n 'Make sure your charset is UTF-8')\n }\n\n // Multiply most significant byte of result by 0xC0\n // and add least significant byte to product\n value = (((value >>> 8) & 0xff) * 0xC0) + (value & 0xff)\n\n // Convert result to a 13-bit binary string\n bitBuffer.put(value, 13)\n }\n}\n\nmodule.exports = KanjiData\n","/**\n * Data mask pattern reference\n * @type {Object}\n */\nexports.Patterns = {\n PATTERN000: 0,\n PATTERN001: 1,\n PATTERN010: 2,\n PATTERN011: 3,\n PATTERN100: 4,\n PATTERN101: 5,\n PATTERN110: 6,\n PATTERN111: 7\n}\n\n/**\n * Weighted penalty scores for the undesirable features\n * @type {Object}\n */\nconst PenaltyScores = {\n N1: 3,\n N2: 3,\n N3: 40,\n N4: 10\n}\n\n/**\n * Check if mask pattern value is valid\n *\n * @param {Number} mask Mask pattern\n * @return {Boolean} true if valid, false otherwise\n */\nexports.isValid = function isValid (mask) {\n return mask != null && mask !== '' && !isNaN(mask) && mask >= 0 && mask <= 7\n}\n\n/**\n * Returns mask pattern from a value.\n * If value is not valid, returns undefined\n *\n * @param {Number|String} value Mask pattern value\n * @return {Number} Valid mask pattern or undefined\n */\nexports.from = function from (value) {\n return exports.isValid(value) ? parseInt(value, 10) : undefined\n}\n\n/**\n* Find adjacent modules in row/column with the same color\n* and assign a penalty value.\n*\n* Points: N1 + i\n* i is the amount by which the number of adjacent modules of the same color exceeds 5\n*/\nexports.getPenaltyN1 = function getPenaltyN1 (data) {\n const size = data.size\n let points = 0\n let sameCountCol = 0\n let sameCountRow = 0\n let lastCol = null\n let lastRow = null\n\n for (let row = 0; row < size; row++) {\n sameCountCol = sameCountRow = 0\n lastCol = lastRow = null\n\n for (let col = 0; col < size; col++) {\n let module = data.get(row, col)\n if (module === lastCol) {\n sameCountCol++\n } else {\n if (sameCountCol >= 5) points += PenaltyScores.N1 + (sameCountCol - 5)\n lastCol = module\n sameCountCol = 1\n }\n\n module = data.get(col, row)\n if (module === lastRow) {\n sameCountRow++\n } else {\n if (sameCountRow >= 5) points += PenaltyScores.N1 + (sameCountRow - 5)\n lastRow = module\n sameCountRow = 1\n }\n }\n\n if (sameCountCol >= 5) points += PenaltyScores.N1 + (sameCountCol - 5)\n if (sameCountRow >= 5) points += PenaltyScores.N1 + (sameCountRow - 5)\n }\n\n return points\n}\n\n/**\n * Find 2x2 blocks with the same color and assign a penalty value\n *\n * Points: N2 * (m - 1) * (n - 1)\n */\nexports.getPenaltyN2 = function getPenaltyN2 (data) {\n const size = data.size\n let points = 0\n\n for (let row = 0; row < size - 1; row++) {\n for (let col = 0; col < size - 1; col++) {\n const last = data.get(row, col) +\n data.get(row, col + 1) +\n data.get(row + 1, col) +\n data.get(row + 1, col + 1)\n\n if (last === 4 || last === 0) points++\n }\n }\n\n return points * PenaltyScores.N2\n}\n\n/**\n * Find 1:1:3:1:1 ratio (dark:light:dark:light:dark) pattern in row/column,\n * preceded or followed by light area 4 modules wide\n *\n * Points: N3 * number of pattern found\n */\nexports.getPenaltyN3 = function getPenaltyN3 (data) {\n const size = data.size\n let points = 0\n let bitsCol = 0\n let bitsRow = 0\n\n for (let row = 0; row < size; row++) {\n bitsCol = bitsRow = 0\n for (let col = 0; col < size; col++) {\n bitsCol = ((bitsCol << 1) & 0x7FF) | data.get(row, col)\n if (col >= 10 && (bitsCol === 0x5D0 || bitsCol === 0x05D)) points++\n\n bitsRow = ((bitsRow << 1) & 0x7FF) | data.get(col, row)\n if (col >= 10 && (bitsRow === 0x5D0 || bitsRow === 0x05D)) points++\n }\n }\n\n return points * PenaltyScores.N3\n}\n\n/**\n * Calculate proportion of dark modules in entire symbol\n *\n * Points: N4 * k\n *\n * k is the rating of the deviation of the proportion of dark modules\n * in the symbol from 50% in steps of 5%\n */\nexports.getPenaltyN4 = function getPenaltyN4 (data) {\n let darkCount = 0\n const modulesCount = data.data.length\n\n for (let i = 0; i < modulesCount; i++) darkCount += data.data[i]\n\n const k = Math.abs(Math.ceil((darkCount * 100 / modulesCount) / 5) - 10)\n\n return k * PenaltyScores.N4\n}\n\n/**\n * Return mask value at given position\n *\n * @param {Number} maskPattern Pattern reference value\n * @param {Number} i Row\n * @param {Number} j Column\n * @return {Boolean} Mask value\n */\nfunction getMaskAt (maskPattern, i, j) {\n switch (maskPattern) {\n case exports.Patterns.PATTERN000: return (i + j) % 2 === 0\n case exports.Patterns.PATTERN001: return i % 2 === 0\n case exports.Patterns.PATTERN010: return j % 3 === 0\n case exports.Patterns.PATTERN011: return (i + j) % 3 === 0\n case exports.Patterns.PATTERN100: return (Math.floor(i / 2) + Math.floor(j / 3)) % 2 === 0\n case exports.Patterns.PATTERN101: return (i * j) % 2 + (i * j) % 3 === 0\n case exports.Patterns.PATTERN110: return ((i * j) % 2 + (i * j) % 3) % 2 === 0\n case exports.Patterns.PATTERN111: return ((i * j) % 3 + (i + j) % 2) % 2 === 0\n\n default: throw new Error('bad maskPattern:' + maskPattern)\n }\n}\n\n/**\n * Apply a mask pattern to a BitMatrix\n *\n * @param {Number} pattern Pattern reference number\n * @param {BitMatrix} data BitMatrix data\n */\nexports.applyMask = function applyMask (pattern, data) {\n const size = data.size\n\n for (let col = 0; col < size; col++) {\n for (let row = 0; row < size; row++) {\n if (data.isReserved(row, col)) continue\n data.xor(row, col, getMaskAt(pattern, row, col))\n }\n }\n}\n\n/**\n * Returns the best mask pattern for data\n *\n * @param {BitMatrix} data\n * @return {Number} Mask pattern reference number\n */\nexports.getBestMask = function getBestMask (data, setupFormatFunc) {\n const numPatterns = Object.keys(exports.Patterns).length\n let bestPattern = 0\n let lowerPenalty = Infinity\n\n for (let p = 0; p < numPatterns; p++) {\n setupFormatFunc(p)\n exports.applyMask(p, data)\n\n // Calculate penalty\n const penalty =\n exports.getPenaltyN1(data) +\n exports.getPenaltyN2(data) +\n exports.getPenaltyN3(data) +\n exports.getPenaltyN4(data)\n\n // Undo previously applied mask\n exports.applyMask(p, data)\n\n if (penalty < lowerPenalty) {\n lowerPenalty = penalty\n bestPattern = p\n }\n }\n\n return bestPattern\n}\n","const VersionCheck = require('./version-check')\nconst Regex = require('./regex')\n\n/**\n * Numeric mode encodes data from the decimal digit set (0 - 9)\n * (byte values 30HEX to 39HEX).\n * Normally, 3 data characters are represented by 10 bits.\n *\n * @type {Object}\n */\nexports.NUMERIC = {\n id: 'Numeric',\n bit: 1 << 0,\n ccBits: [10, 12, 14]\n}\n\n/**\n * Alphanumeric mode encodes data from a set of 45 characters,\n * i.e. 10 numeric digits (0 - 9),\n * 26 alphabetic characters (A - Z),\n * and 9 symbols (SP, $, %, *, +, -, ., /, :).\n * Normally, two input characters are represented by 11 bits.\n *\n * @type {Object}\n */\nexports.ALPHANUMERIC = {\n id: 'Alphanumeric',\n bit: 1 << 1,\n ccBits: [9, 11, 13]\n}\n\n/**\n * In byte mode, data is encoded at 8 bits per character.\n *\n * @type {Object}\n */\nexports.BYTE = {\n id: 'Byte',\n bit: 1 << 2,\n ccBits: [8, 16, 16]\n}\n\n/**\n * The Kanji mode efficiently encodes Kanji characters in accordance with\n * the Shift JIS system based on JIS X 0208.\n * The Shift JIS values are shifted from the JIS X 0208 values.\n * JIS X 0208 gives details of the shift coded representation.\n * Each two-byte character value is compacted to a 13-bit binary codeword.\n *\n * @type {Object}\n */\nexports.KANJI = {\n id: 'Kanji',\n bit: 1 << 3,\n ccBits: [8, 10, 12]\n}\n\n/**\n * Mixed mode will contain a sequences of data in a combination of any of\n * the modes described above\n *\n * @type {Object}\n */\nexports.MIXED = {\n bit: -1\n}\n\n/**\n * Returns the number of bits needed to store the data length\n * according to QR Code specifications.\n *\n * @param {Mode} mode Data mode\n * @param {Number} version QR Code version\n * @return {Number} Number of bits\n */\nexports.getCharCountIndicator = function getCharCountIndicator (mode, version) {\n if (!mode.ccBits) throw new Error('Invalid mode: ' + mode)\n\n if (!VersionCheck.isValid(version)) {\n throw new Error('Invalid version: ' + version)\n }\n\n if (version >= 1 && version < 10) return mode.ccBits[0]\n else if (version < 27) return mode.ccBits[1]\n return mode.ccBits[2]\n}\n\n/**\n * Returns the most efficient mode to store the specified data\n *\n * @param {String} dataStr Input data string\n * @return {Mode} Best mode\n */\nexports.getBestModeForData = function getBestModeForData (dataStr) {\n if (Regex.testNumeric(dataStr)) return exports.NUMERIC\n else if (Regex.testAlphanumeric(dataStr)) return exports.ALPHANUMERIC\n else if (Regex.testKanji(dataStr)) return exports.KANJI\n else return exports.BYTE\n}\n\n/**\n * Return mode name as string\n *\n * @param {Mode} mode Mode object\n * @returns {String} Mode name\n */\nexports.toString = function toString (mode) {\n if (mode && mode.id) return mode.id\n throw new Error('Invalid mode')\n}\n\n/**\n * Check if input param is a valid mode object\n *\n * @param {Mode} mode Mode object\n * @returns {Boolean} True if valid mode, false otherwise\n */\nexports.isValid = function isValid (mode) {\n return mode && mode.bit && mode.ccBits\n}\n\n/**\n * Get mode object from its name\n *\n * @param {String} string Mode name\n * @returns {Mode} Mode object\n */\nfunction fromString (string) {\n if (typeof string !== 'string') {\n throw new Error('Param is not a string')\n }\n\n const lcStr = string.toLowerCase()\n\n switch (lcStr) {\n case 'numeric':\n return exports.NUMERIC\n case 'alphanumeric':\n return exports.ALPHANUMERIC\n case 'kanji':\n return exports.KANJI\n case 'byte':\n return exports.BYTE\n default:\n throw new Error('Unknown mode: ' + string)\n }\n}\n\n/**\n * Returns mode from a value.\n * If value is not a valid mode, returns defaultValue\n *\n * @param {Mode|String} value Encoding mode\n * @param {Mode} defaultValue Fallback value\n * @return {Mode} Encoding mode\n */\nexports.from = function from (value, defaultValue) {\n if (exports.isValid(value)) {\n return value\n }\n\n try {\n return fromString(value)\n } catch (e) {\n return defaultValue\n }\n}\n","const Mode = require('./mode')\n\nfunction NumericData (data) {\n this.mode = Mode.NUMERIC\n this.data = data.toString()\n}\n\nNumericData.getBitsLength = function getBitsLength (length) {\n return 10 * Math.floor(length / 3) + ((length % 3) ? ((length % 3) * 3 + 1) : 0)\n}\n\nNumericData.prototype.getLength = function getLength () {\n return this.data.length\n}\n\nNumericData.prototype.getBitsLength = function getBitsLength () {\n return NumericData.getBitsLength(this.data.length)\n}\n\nNumericData.prototype.write = function write (bitBuffer) {\n let i, group, value\n\n // The input data string is divided into groups of three digits,\n // and each group is converted to its 10-bit binary equivalent.\n for (i = 0; i + 3 <= this.data.length; i += 3) {\n group = this.data.substr(i, 3)\n value = parseInt(group, 10)\n\n bitBuffer.put(value, 10)\n }\n\n // If the number of input digits is not an exact multiple of three,\n // the final one or two digits are converted to 4 or 7 bits respectively.\n const remainingNum = this.data.length - i\n if (remainingNum > 0) {\n group = this.data.substr(i)\n value = parseInt(group, 10)\n\n bitBuffer.put(value, remainingNum * 3 + 1)\n }\n}\n\nmodule.exports = NumericData\n","const GF = require('./galois-field')\n\n/**\n * Multiplies two polynomials inside Galois Field\n *\n * @param {Uint8Array} p1 Polynomial\n * @param {Uint8Array} p2 Polynomial\n * @return {Uint8Array} Product of p1 and p2\n */\nexports.mul = function mul (p1, p2) {\n const coeff = new Uint8Array(p1.length + p2.length - 1)\n\n for (let i = 0; i < p1.length; i++) {\n for (let j = 0; j < p2.length; j++) {\n coeff[i + j] ^= GF.mul(p1[i], p2[j])\n }\n }\n\n return coeff\n}\n\n/**\n * Calculate the remainder of polynomials division\n *\n * @param {Uint8Array} divident Polynomial\n * @param {Uint8Array} divisor Polynomial\n * @return {Uint8Array} Remainder\n */\nexports.mod = function mod (divident, divisor) {\n let result = new Uint8Array(divident)\n\n while ((result.length - divisor.length) >= 0) {\n const coeff = result[0]\n\n for (let i = 0; i < divisor.length; i++) {\n result[i] ^= GF.mul(divisor[i], coeff)\n }\n\n // remove all zeros from buffer head\n let offset = 0\n while (offset < result.length && result[offset] === 0) offset++\n result = result.slice(offset)\n }\n\n return result\n}\n\n/**\n * Generate an irreducible generator polynomial of specified degree\n * (used by Reed-Solomon encoder)\n *\n * @param {Number} degree Degree of the generator polynomial\n * @return {Uint8Array} Buffer containing polynomial coefficients\n */\nexports.generateECPolynomial = function generateECPolynomial (degree) {\n let poly = new Uint8Array([1])\n for (let i = 0; i < degree; i++) {\n poly = exports.mul(poly, new Uint8Array([1, GF.exp(i)]))\n }\n\n return poly\n}\n","const Utils = require('./utils')\nconst ECLevel = require('./error-correction-level')\nconst BitBuffer = require('./bit-buffer')\nconst BitMatrix = require('./bit-matrix')\nconst AlignmentPattern = require('./alignment-pattern')\nconst FinderPattern = require('./finder-pattern')\nconst MaskPattern = require('./mask-pattern')\nconst ECCode = require('./error-correction-code')\nconst ReedSolomonEncoder = require('./reed-solomon-encoder')\nconst Version = require('./version')\nconst FormatInfo = require('./format-info')\nconst Mode = require('./mode')\nconst Segments = require('./segments')\n\n/**\n * QRCode for JavaScript\n *\n * modified by Ryan Day for nodejs support\n * Copyright (c) 2011 Ryan Day\n *\n * Licensed under the MIT license:\n * http://www.opensource.org/licenses/mit-license.php\n *\n//---------------------------------------------------------------------\n// QRCode for JavaScript\n//\n// Copyright (c) 2009 Kazuhiko Arase\n//\n// URL: http://www.d-project.com/\n//\n// Licensed under the MIT license:\n// http://www.opensource.org/licenses/mit-license.php\n//\n// The word \"QR Code\" is registered trademark of\n// DENSO WAVE INCORPORATED\n// http://www.denso-wave.com/qrcode/faqpatent-e.html\n//\n//---------------------------------------------------------------------\n*/\n\n/**\n * Add finder patterns bits to matrix\n *\n * @param {BitMatrix} matrix Modules matrix\n * @param {Number} version QR Code version\n */\nfunction setupFinderPattern (matrix, version) {\n const size = matrix.size\n const pos = FinderPattern.getPositions(version)\n\n for (let i = 0; i < pos.length; i++) {\n const row = pos[i][0]\n const col = pos[i][1]\n\n for (let r = -1; r <= 7; r++) {\n if (row + r <= -1 || size <= row + r) continue\n\n for (let c = -1; c <= 7; c++) {\n if (col + c <= -1 || size <= col + c) continue\n\n if ((r >= 0 && r <= 6 && (c === 0 || c === 6)) ||\n (c >= 0 && c <= 6 && (r === 0 || r === 6)) ||\n (r >= 2 && r <= 4 && c >= 2 && c <= 4)) {\n matrix.set(row + r, col + c, true, true)\n } else {\n matrix.set(row + r, col + c, false, true)\n }\n }\n }\n }\n}\n\n/**\n * Add timing pattern bits to matrix\n *\n * Note: this function must be called before {@link setupAlignmentPattern}\n *\n * @param {BitMatrix} matrix Modules matrix\n */\nfunction setupTimingPattern (matrix) {\n const size = matrix.size\n\n for (let r = 8; r < size - 8; r++) {\n const value = r % 2 === 0\n matrix.set(r, 6, value, true)\n matrix.set(6, r, value, true)\n }\n}\n\n/**\n * Add alignment patterns bits to matrix\n *\n * Note: this function must be called after {@link setupTimingPattern}\n *\n * @param {BitMatrix} matrix Modules matrix\n * @param {Number} version QR Code version\n */\nfunction setupAlignmentPattern (matrix, version) {\n const pos = AlignmentPattern.getPositions(version)\n\n for (let i = 0; i < pos.length; i++) {\n const row = pos[i][0]\n const col = pos[i][1]\n\n for (let r = -2; r <= 2; r++) {\n for (let c = -2; c <= 2; c++) {\n if (r === -2 || r === 2 || c === -2 || c === 2 ||\n (r === 0 && c === 0)) {\n matrix.set(row + r, col + c, true, true)\n } else {\n matrix.set(row + r, col + c, false, true)\n }\n }\n }\n }\n}\n\n/**\n * Add version info bits to matrix\n *\n * @param {BitMatrix} matrix Modules matrix\n * @param {Number} version QR Code version\n */\nfunction setupVersionInfo (matrix, version) {\n const size = matrix.size\n const bits = Version.getEncodedBits(version)\n let row, col, mod\n\n for (let i = 0; i < 18; i++) {\n row = Math.floor(i / 3)\n col = i % 3 + size - 8 - 3\n mod = ((bits >> i) & 1) === 1\n\n matrix.set(row, col, mod, true)\n matrix.set(col, row, mod, true)\n }\n}\n\n/**\n * Add format info bits to matrix\n *\n * @param {BitMatrix} matrix Modules matrix\n * @param {ErrorCorrectionLevel} errorCorrectionLevel Error correction level\n * @param {Number} maskPattern Mask pattern reference value\n */\nfunction setupFormatInfo (matrix, errorCorrectionLevel, maskPattern) {\n const size = matrix.size\n const bits = FormatInfo.getEncodedBits(errorCorrectionLevel, maskPattern)\n let i, mod\n\n for (i = 0; i < 15; i++) {\n mod = ((bits >> i) & 1) === 1\n\n // vertical\n if (i < 6) {\n matrix.set(i, 8, mod, true)\n } else if (i < 8) {\n matrix.set(i + 1, 8, mod, true)\n } else {\n matrix.set(size - 15 + i, 8, mod, true)\n }\n\n // horizontal\n if (i < 8) {\n matrix.set(8, size - i - 1, mod, true)\n } else if (i < 9) {\n matrix.set(8, 15 - i - 1 + 1, mod, true)\n } else {\n matrix.set(8, 15 - i - 1, mod, true)\n }\n }\n\n // fixed module\n matrix.set(size - 8, 8, 1, true)\n}\n\n/**\n * Add encoded data bits to matrix\n *\n * @param {BitMatrix} matrix Modules matrix\n * @param {Uint8Array} data Data codewords\n */\nfunction setupData (matrix, data) {\n const size = matrix.size\n let inc = -1\n let row = size - 1\n let bitIndex = 7\n let byteIndex = 0\n\n for (let col = size - 1; col > 0; col -= 2) {\n if (col === 6) col--\n\n while (true) {\n for (let c = 0; c < 2; c++) {\n if (!matrix.isReserved(row, col - c)) {\n let dark = false\n\n if (byteIndex < data.length) {\n dark = (((data[byteIndex] >>> bitIndex) & 1) === 1)\n }\n\n matrix.set(row, col - c, dark)\n bitIndex--\n\n if (bitIndex === -1) {\n byteIndex++\n bitIndex = 7\n }\n }\n }\n\n row += inc\n\n if (row < 0 || size <= row) {\n row -= inc\n inc = -inc\n break\n }\n }\n }\n}\n\n/**\n * Create encoded codewords from data input\n *\n * @param {Number} version QR Code version\n * @param {ErrorCorrectionLevel} errorCorrectionLevel Error correction level\n * @param {ByteData} data Data input\n * @return {Uint8Array} Buffer containing encoded codewords\n */\nfunction createData (version, errorCorrectionLevel, segments) {\n // Prepare data buffer\n const buffer = new BitBuffer()\n\n segments.forEach(function (data) {\n // prefix data with mode indicator (4 bits)\n buffer.put(data.mode.bit, 4)\n\n // Prefix data with character count indicator.\n // The character count indicator is a string of bits that represents the\n // number of characters that are being encoded.\n // The character count indicator must be placed after the mode indicator\n // and must be a certain number of bits long, depending on the QR version\n // and data mode\n // @see {@link Mode.getCharCountIndicator}.\n buffer.put(data.getLength(), Mode.getCharCountIndicator(data.mode, version))\n\n // add binary data sequence to buffer\n data.write(buffer)\n })\n\n // Calculate required number of bits\n const totalCodewords = Utils.getSymbolTotalCodewords(version)\n const ecTotalCodewords = ECCode.getTotalCodewordsCount(version, errorCorrectionLevel)\n const dataTotalCodewordsBits = (totalCodewords - ecTotalCodewords) * 8\n\n // Add a terminator.\n // If the bit string is shorter than the total number of required bits,\n // a terminator of up to four 0s must be added to the right side of the string.\n // If the bit string is more than four bits shorter than the required number of bits,\n // add four 0s to the end.\n if (buffer.getLengthInBits() + 4 <= dataTotalCodewordsBits) {\n buffer.put(0, 4)\n }\n\n // If the bit string is fewer than four bits shorter, add only the number of 0s that\n // are needed to reach the required number of bits.\n\n // After adding the terminator, if the number of bits in the string is not a multiple of 8,\n // pad the string on the right with 0s to make the string's length a multiple of 8.\n while (buffer.getLengthInBits() % 8 !== 0) {\n buffer.putBit(0)\n }\n\n // Add pad bytes if the string is still shorter than the total number of required bits.\n // Extend the buffer to fill the data capacity of the symbol corresponding to\n // the Version and Error Correction Level by adding the Pad Codewords 11101100 (0xEC)\n // and 00010001 (0x11) alternately.\n const remainingByte = (dataTotalCodewordsBits - buffer.getLengthInBits()) / 8\n for (let i = 0; i < remainingByte; i++) {\n buffer.put(i % 2 ? 0x11 : 0xEC, 8)\n }\n\n return createCodewords(buffer, version, errorCorrectionLevel)\n}\n\n/**\n * Encode input data with Reed-Solomon and return codewords with\n * relative error correction bits\n *\n * @param {BitBuffer} bitBuffer Data to encode\n * @param {Number} version QR Code version\n * @param {ErrorCorrectionLevel} errorCorrectionLevel Error correction level\n * @return {Uint8Array} Buffer containing encoded codewords\n */\nfunction createCodewords (bitBuffer, version, errorCorrectionLevel) {\n // Total codewords for this QR code version (Data + Error correction)\n const totalCodewords = Utils.getSymbolTotalCodewords(version)\n\n // Total number of error correction codewords\n const ecTotalCodewords = ECCode.getTotalCodewordsCount(version, errorCorrectionLevel)\n\n // Total number of data codewords\n const dataTotalCodewords = totalCodewords - ecTotalCodewords\n\n // Total number of blocks\n const ecTotalBlocks = ECCode.getBlocksCount(version, errorCorrectionLevel)\n\n // Calculate how many blocks each group should contain\n const blocksInGroup2 = totalCodewords % ecTotalBlocks\n const blocksInGroup1 = ecTotalBlocks - blocksInGroup2\n\n const totalCodewordsInGroup1 = Math.floor(totalCodewords / ecTotalBlocks)\n\n const dataCodewordsInGroup1 = Math.floor(dataTotalCodewords / ecTotalBlocks)\n const dataCodewordsInGroup2 = dataCodewordsInGroup1 + 1\n\n // Number of EC codewords is the same for both groups\n const ecCount = totalCodewordsInGroup1 - dataCodewordsInGroup1\n\n // Initialize a Reed-Solomon encoder with a generator polynomial of degree ecCount\n const rs = new ReedSolomonEncoder(ecCount)\n\n let offset = 0\n const dcData = new Array(ecTotalBlocks)\n const ecData = new Array(ecTotalBlocks)\n let maxDataSize = 0\n const buffer = new Uint8Array(bitBuffer.buffer)\n\n // Divide the buffer into the required number of blocks\n for (let b = 0; b < ecTotalBlocks; b++) {\n const dataSize = b < blocksInGroup1 ? dataCodewordsInGroup1 : dataCodewordsInGroup2\n\n // extract a block of data from buffer\n dcData[b] = buffer.slice(offset, offset + dataSize)\n\n // Calculate EC codewords for this data block\n ecData[b] = rs.encode(dcData[b])\n\n offset += dataSize\n maxDataSize = Math.max(maxDataSize, dataSize)\n }\n\n // Create final data\n // Interleave the data and error correction codewords from each block\n const data = new Uint8Array(totalCodewords)\n let index = 0\n let i, r\n\n // Add data codewords\n for (i = 0; i < maxDataSize; i++) {\n for (r = 0; r < ecTotalBlocks; r++) {\n if (i < dcData[r].length) {\n data[index++] = dcData[r][i]\n }\n }\n }\n\n // Apped EC codewords\n for (i = 0; i < ecCount; i++) {\n for (r = 0; r < ecTotalBlocks; r++) {\n data[index++] = ecData[r][i]\n }\n }\n\n return data\n}\n\n/**\n * Build QR Code symbol\n *\n * @param {String} data Input string\n * @param {Number} version QR Code version\n * @param {ErrorCorretionLevel} errorCorrectionLevel Error level\n * @param {MaskPattern} maskPattern Mask pattern\n * @return {Object} Object containing symbol data\n */\nfunction createSymbol (data, version, errorCorrectionLevel, maskPattern) {\n let segments\n\n if (Array.isArray(data)) {\n segments = Segments.fromArray(data)\n } else if (typeof data === 'string') {\n let estimatedVersion = version\n\n if (!estimatedVersion) {\n const rawSegments = Segments.rawSplit(data)\n\n // Estimate best version that can contain raw splitted segments\n estimatedVersion = Version.getBestVersionForData(rawSegments, errorCorrectionLevel)\n }\n\n // Build optimized segments\n // If estimated version is undefined, try with the highest version\n segments = Segments.fromString(data, estimatedVersion || 40)\n } else {\n throw new Error('Invalid data')\n }\n\n // Get the min version that can contain data\n const bestVersion = Version.getBestVersionForData(segments, errorCorrectionLevel)\n\n // If no version is found, data cannot be stored\n if (!bestVersion) {\n throw new Error('The amount of data is too big to be stored in a QR Code')\n }\n\n // If not specified, use min version as default\n if (!version) {\n version = bestVersion\n\n // Check if the specified version can contain the data\n } else if (version < bestVersion) {\n throw new Error('\\n' +\n 'The chosen QR Code version cannot contain this amount of data.\\n' +\n 'Minimum version required to store current data is: ' + bestVersion + '.\\n'\n )\n }\n\n const dataBits = createData(version, errorCorrectionLevel, segments)\n\n // Allocate matrix buffer\n const moduleCount = Utils.getSymbolSize(version)\n const modules = new BitMatrix(moduleCount)\n\n // Add function modules\n setupFinderPattern(modules, version)\n setupTimingPattern(modules)\n setupAlignmentPattern(modules, version)\n\n // Add temporary dummy bits for format info just to set them as reserved.\n // This is needed to prevent these bits from being masked by {@link MaskPattern.applyMask}\n // since the masking operation must be performed only on the encoding region.\n // These blocks will be replaced with correct values later in code.\n setupFormatInfo(modules, errorCorrectionLevel, 0)\n\n if (version >= 7) {\n setupVersionInfo(modules, version)\n }\n\n // Add data codewords\n setupData(modules, dataBits)\n\n if (isNaN(maskPattern)) {\n // Find best mask pattern\n maskPattern = MaskPattern.getBestMask(modules,\n setupFormatInfo.bind(null, modules, errorCorrectionLevel))\n }\n\n // Apply mask pattern\n MaskPattern.applyMask(maskPattern, modules)\n\n // Replace format info bits with correct values\n setupFormatInfo(modules, errorCorrectionLevel, maskPattern)\n\n return {\n modules: modules,\n version: version,\n errorCorrectionLevel: errorCorrectionLevel,\n maskPattern: maskPattern,\n segments: segments\n }\n}\n\n/**\n * QR Code\n *\n * @param {String | Array} data Input data\n * @param {Object} options Optional configurations\n * @param {Number} options.version QR Code version\n * @param {String} options.errorCorrectionLevel Error correction level\n * @param {Function} options.toSJISFunc Helper func to convert utf8 to sjis\n */\nexports.create = function create (data, options) {\n if (typeof data === 'undefined' || data === '') {\n throw new Error('No input text')\n }\n\n let errorCorrectionLevel = ECLevel.M\n let version\n let mask\n\n if (typeof options !== 'undefined') {\n // Use higher error correction level as default\n errorCorrectionLevel = ECLevel.from(options.errorCorrectionLevel, ECLevel.M)\n version = Version.from(options.version)\n mask = MaskPattern.from(options.maskPattern)\n\n if (options.toSJISFunc) {\n Utils.setToSJISFunction(options.toSJISFunc)\n }\n }\n\n return createSymbol(data, version, errorCorrectionLevel, mask)\n}\n","const Polynomial = require('./polynomial')\n\nfunction ReedSolomonEncoder (degree) {\n this.genPoly = undefined\n this.degree = degree\n\n if (this.degree) this.initialize(this.degree)\n}\n\n/**\n * Initialize the encoder.\n * The input param should correspond to the number of error correction codewords.\n *\n * @param {Number} degree\n */\nReedSolomonEncoder.prototype.initialize = function initialize (degree) {\n // create an irreducible generator polynomial\n this.degree = degree\n this.genPoly = Polynomial.generateECPolynomial(this.degree)\n}\n\n/**\n * Encodes a chunk of data\n *\n * @param {Uint8Array} data Buffer containing input data\n * @return {Uint8Array} Buffer containing encoded data\n */\nReedSolomonEncoder.prototype.encode = function encode (data) {\n if (!this.genPoly) {\n throw new Error('Encoder not initialized')\n }\n\n // Calculate EC for this data block\n // extends data size to data+genPoly size\n const paddedData = new Uint8Array(data.length + this.degree)\n paddedData.set(data)\n\n // The error correction codewords are the remainder after dividing the data codewords\n // by a generator polynomial\n const remainder = Polynomial.mod(paddedData, this.genPoly)\n\n // return EC data blocks (last n byte, where n is the degree of genPoly)\n // If coefficients number in remainder are less than genPoly degree,\n // pad with 0s to the left to reach the needed number of coefficients\n const start = this.degree - remainder.length\n if (start > 0) {\n const buff = new Uint8Array(this.degree)\n buff.set(remainder, start)\n\n return buff\n }\n\n return remainder\n}\n\nmodule.exports = ReedSolomonEncoder\n","const numeric = '[0-9]+'\nconst alphanumeric = '[A-Z $%*+\\\\-./:]+'\nlet kanji = '(?:[u3000-u303F]|[u3040-u309F]|[u30A0-u30FF]|' +\n '[uFF00-uFFEF]|[u4E00-u9FAF]|[u2605-u2606]|[u2190-u2195]|u203B|' +\n '[u2010u2015u2018u2019u2025u2026u201Cu201Du2225u2260]|' +\n '[u0391-u0451]|[u00A7u00A8u00B1u00B4u00D7u00F7])+'\nkanji = kanji.replace(/u/g, '\\\\u')\n\nconst byte = '(?:(?![A-Z0-9 $%*+\\\\-./:]|' + kanji + ')(?:.|[\\r\\n]))+'\n\nexports.KANJI = new RegExp(kanji, 'g')\nexports.BYTE_KANJI = new RegExp('[^A-Z0-9 $%*+\\\\-./:]+', 'g')\nexports.BYTE = new RegExp(byte, 'g')\nexports.NUMERIC = new RegExp(numeric, 'g')\nexports.ALPHANUMERIC = new RegExp(alphanumeric, 'g')\n\nconst TEST_KANJI = new RegExp('^' + kanji + '$')\nconst TEST_NUMERIC = new RegExp('^' + numeric + '$')\nconst TEST_ALPHANUMERIC = new RegExp('^[A-Z0-9 $%*+\\\\-./:]+$')\n\nexports.testKanji = function testKanji (str) {\n return TEST_KANJI.test(str)\n}\n\nexports.testNumeric = function testNumeric (str) {\n return TEST_NUMERIC.test(str)\n}\n\nexports.testAlphanumeric = function testAlphanumeric (str) {\n return TEST_ALPHANUMERIC.test(str)\n}\n","const Mode = require('./mode')\nconst NumericData = require('./numeric-data')\nconst AlphanumericData = require('./alphanumeric-data')\nconst ByteData = require('./byte-data')\nconst KanjiData = require('./kanji-data')\nconst Regex = require('./regex')\nconst Utils = require('./utils')\nconst dijkstra = require('dijkstrajs')\n\n/**\n * Returns UTF8 byte length\n *\n * @param {String} str Input string\n * @return {Number} Number of byte\n */\nfunction getStringByteLength (str) {\n return unescape(encodeURIComponent(str)).length\n}\n\n/**\n * Get a list of segments of the specified mode\n * from a string\n *\n * @param {Mode} mode Segment mode\n * @param {String} str String to process\n * @return {Array} Array of object with segments data\n */\nfunction getSegments (regex, mode, str) {\n const segments = []\n let result\n\n while ((result = regex.exec(str)) !== null) {\n segments.push({\n data: result[0],\n index: result.index,\n mode: mode,\n length: result[0].length\n })\n }\n\n return segments\n}\n\n/**\n * Extracts a series of segments with the appropriate\n * modes from a string\n *\n * @param {String} dataStr Input string\n * @return {Array} Array of object with segments data\n */\nfunction getSegmentsFromString (dataStr) {\n const numSegs = getSegments(Regex.NUMERIC, Mode.NUMERIC, dataStr)\n const alphaNumSegs = getSegments(Regex.ALPHANUMERIC, Mode.ALPHANUMERIC, dataStr)\n let byteSegs\n let kanjiSegs\n\n if (Utils.isKanjiModeEnabled()) {\n byteSegs = getSegments(Regex.BYTE, Mode.BYTE, dataStr)\n kanjiSegs = getSegments(Regex.KANJI, Mode.KANJI, dataStr)\n } else {\n byteSegs = getSegments(Regex.BYTE_KANJI, Mode.BYTE, dataStr)\n kanjiSegs = []\n }\n\n const segs = numSegs.concat(alphaNumSegs, byteSegs, kanjiSegs)\n\n return segs\n .sort(function (s1, s2) {\n return s1.index - s2.index\n })\n .map(function (obj) {\n return {\n data: obj.data,\n mode: obj.mode,\n length: obj.length\n }\n })\n}\n\n/**\n * Returns how many bits are needed to encode a string of\n * specified length with the specified mode\n *\n * @param {Number} length String length\n * @param {Mode} mode Segment mode\n * @return {Number} Bit length\n */\nfunction getSegmentBitsLength (length, mode) {\n switch (mode) {\n case Mode.NUMERIC:\n return NumericData.getBitsLength(length)\n case Mode.ALPHANUMERIC:\n return AlphanumericData.getBitsLength(length)\n case Mode.KANJI:\n return KanjiData.getBitsLength(length)\n case Mode.BYTE:\n return ByteData.getBitsLength(length)\n }\n}\n\n/**\n * Merges adjacent segments which have the same mode\n *\n * @param {Array} segs Array of object with segments data\n * @return {Array} Array of object with segments data\n */\nfunction mergeSegments (segs) {\n return segs.reduce(function (acc, curr) {\n const prevSeg = acc.length - 1 >= 0 ? acc[acc.length - 1] : null\n if (prevSeg && prevSeg.mode === curr.mode) {\n acc[acc.length - 1].data += curr.data\n return acc\n }\n\n acc.push(curr)\n return acc\n }, [])\n}\n\n/**\n * Generates a list of all possible nodes combination which\n * will be used to build a segments graph.\n *\n * Nodes are divided by groups. Each group will contain a list of all the modes\n * in which is possible to encode the given text.\n *\n * For example the text '12345' can be encoded as Numeric, Alphanumeric or Byte.\n * The group for '12345' will contain then 3 objects, one for each\n * possible encoding mode.\n *\n * Each node represents a possible segment.\n *\n * @param {Array} segs Array of object with segments data\n * @return {Array} Array of object with segments data\n */\nfunction buildNodes (segs) {\n const nodes = []\n for (let i = 0; i < segs.length; i++) {\n const seg = segs[i]\n\n switch (seg.mode) {\n case Mode.NUMERIC:\n nodes.push([seg,\n { data: seg.data, mode: Mode.ALPHANUMERIC, length: seg.length },\n { data: seg.data, mode: Mode.BYTE, length: seg.length }\n ])\n break\n case Mode.ALPHANUMERIC:\n nodes.push([seg,\n { data: seg.data, mode: Mode.BYTE, length: seg.length }\n ])\n break\n case Mode.KANJI:\n nodes.push([seg,\n { data: seg.data, mode: Mode.BYTE, length: getStringByteLength(seg.data) }\n ])\n break\n case Mode.BYTE:\n nodes.push([\n { data: seg.data, mode: Mode.BYTE, length: getStringByteLength(seg.data) }\n ])\n }\n }\n\n return nodes\n}\n\n/**\n * Builds a graph from a list of nodes.\n * All segments in each node group will be connected with all the segments of\n * the next group and so on.\n *\n * At each connection will be assigned a weight depending on the\n * segment's byte length.\n *\n * @param {Array} nodes Array of object with segments data\n * @param {Number} version QR Code version\n * @return {Object} Graph of all possible segments\n */\nfunction buildGraph (nodes, version) {\n const table = {}\n const graph = { start: {} }\n let prevNodeIds = ['start']\n\n for (let i = 0; i < nodes.length; i++) {\n const nodeGroup = nodes[i]\n const currentNodeIds = []\n\n for (let j = 0; j < nodeGroup.length; j++) {\n const node = nodeGroup[j]\n const key = '' + i + j\n\n currentNodeIds.push(key)\n table[key] = { node: node, lastCount: 0 }\n graph[key] = {}\n\n for (let n = 0; n < prevNodeIds.length; n++) {\n const prevNodeId = prevNodeIds[n]\n\n if (table[prevNodeId] && table[prevNodeId].node.mode === node.mode) {\n graph[prevNodeId][key] =\n getSegmentBitsLength(table[prevNodeId].lastCount + node.length, node.mode) -\n getSegmentBitsLength(table[prevNodeId].lastCount, node.mode)\n\n table[prevNodeId].lastCount += node.length\n } else {\n if (table[prevNodeId]) table[prevNodeId].lastCount = node.length\n\n graph[prevNodeId][key] = getSegmentBitsLength(node.length, node.mode) +\n 4 + Mode.getCharCountIndicator(node.mode, version) // switch cost\n }\n }\n }\n\n prevNodeIds = currentNodeIds\n }\n\n for (let n = 0; n < prevNodeIds.length; n++) {\n graph[prevNodeIds[n]].end = 0\n }\n\n return { map: graph, table: table }\n}\n\n/**\n * Builds a segment from a specified data and mode.\n * If a mode is not specified, the more suitable will be used.\n *\n * @param {String} data Input data\n * @param {Mode | String} modesHint Data mode\n * @return {Segment} Segment\n */\nfunction buildSingleSegment (data, modesHint) {\n let mode\n const bestMode = Mode.getBestModeForData(data)\n\n mode = Mode.from(modesHint, bestMode)\n\n // Make sure data can be encoded\n if (mode !== Mode.BYTE && mode.bit < bestMode.bit) {\n throw new Error('\"' + data + '\"' +\n ' cannot be encoded with mode ' + Mode.toString(mode) +\n '.\\n Suggested mode is: ' + Mode.toString(bestMode))\n }\n\n // Use Mode.BYTE if Kanji support is disabled\n if (mode === Mode.KANJI && !Utils.isKanjiModeEnabled()) {\n mode = Mode.BYTE\n }\n\n switch (mode) {\n case Mode.NUMERIC:\n return new NumericData(data)\n\n case Mode.ALPHANUMERIC:\n return new AlphanumericData(data)\n\n case Mode.KANJI:\n return new KanjiData(data)\n\n case Mode.BYTE:\n return new ByteData(data)\n }\n}\n\n/**\n * Builds a list of segments from an array.\n * Array can contain Strings or Objects with segment's info.\n *\n * For each item which is a string, will be generated a segment with the given\n * string and the more appropriate encoding mode.\n *\n * For each item which is an object, will be generated a segment with the given\n * data and mode.\n * Objects must contain at least the property \"data\".\n * If property \"mode\" is not present, the more suitable mode will be used.\n *\n * @param {Array} array Array of objects with segments data\n * @return {Array} Array of Segments\n */\nexports.fromArray = function fromArray (array) {\n return array.reduce(function (acc, seg) {\n if (typeof seg === 'string') {\n acc.push(buildSingleSegment(seg, null))\n } else if (seg.data) {\n acc.push(buildSingleSegment(seg.data, seg.mode))\n }\n\n return acc\n }, [])\n}\n\n/**\n * Builds an optimized sequence of segments from a string,\n * which will produce the shortest possible bitstream.\n *\n * @param {String} data Input string\n * @param {Number} version QR Code version\n * @return {Array} Array of segments\n */\nexports.fromString = function fromString (data, version) {\n const segs = getSegmentsFromString(data, Utils.isKanjiModeEnabled())\n\n const nodes = buildNodes(segs)\n const graph = buildGraph(nodes, version)\n const path = dijkstra.find_path(graph.map, 'start', 'end')\n\n const optimizedSegs = []\n for (let i = 1; i < path.length - 1; i++) {\n optimizedSegs.push(graph.table[path[i]].node)\n }\n\n return exports.fromArray(mergeSegments(optimizedSegs))\n}\n\n/**\n * Splits a string in various segments with the modes which\n * best represent their content.\n * The produced segments are far from being optimized.\n * The output of this function is only used to estimate a QR Code version\n * which may contain the data.\n *\n * @param {string} data Input string\n * @return {Array} Array of segments\n */\nexports.rawSplit = function rawSplit (data) {\n return exports.fromArray(\n getSegmentsFromString(data, Utils.isKanjiModeEnabled())\n )\n}\n","let toSJISFunction\nconst CODEWORDS_COUNT = [\n 0, // Not used\n 26, 44, 70, 100, 134, 172, 196, 242, 292, 346,\n 404, 466, 532, 581, 655, 733, 815, 901, 991, 1085,\n 1156, 1258, 1364, 1474, 1588, 1706, 1828, 1921, 2051, 2185,\n 2323, 2465, 2611, 2761, 2876, 3034, 3196, 3362, 3532, 3706\n]\n\n/**\n * Returns the QR Code size for the specified version\n *\n * @param {Number} version QR Code version\n * @return {Number} size of QR code\n */\nexports.getSymbolSize = function getSymbolSize (version) {\n if (!version) throw new Error('\"version\" cannot be null or undefined')\n if (version < 1 || version > 40) throw new Error('\"version\" should be in range from 1 to 40')\n return version * 4 + 17\n}\n\n/**\n * Returns the total number of codewords used to store data and EC information.\n *\n * @param {Number} version QR Code version\n * @return {Number} Data length in bits\n */\nexports.getSymbolTotalCodewords = function getSymbolTotalCodewords (version) {\n return CODEWORDS_COUNT[version]\n}\n\n/**\n * Encode data with Bose-Chaudhuri-Hocquenghem\n *\n * @param {Number} data Value to encode\n * @return {Number} Encoded value\n */\nexports.getBCHDigit = function (data) {\n let digit = 0\n\n while (data !== 0) {\n digit++\n data >>>= 1\n }\n\n return digit\n}\n\nexports.setToSJISFunction = function setToSJISFunction (f) {\n if (typeof f !== 'function') {\n throw new Error('\"toSJISFunc\" is not a valid function.')\n }\n\n toSJISFunction = f\n}\n\nexports.isKanjiModeEnabled = function () {\n return typeof toSJISFunction !== 'undefined'\n}\n\nexports.toSJIS = function toSJIS (kanji) {\n return toSJISFunction(kanji)\n}\n","/**\n * Check if QR Code version is valid\n *\n * @param {Number} version QR Code version\n * @return {Boolean} true if valid version, false otherwise\n */\nexports.isValid = function isValid (version) {\n return !isNaN(version) && version >= 1 && version <= 40\n}\n","const Utils = require('./utils')\nconst ECCode = require('./error-correction-code')\nconst ECLevel = require('./error-correction-level')\nconst Mode = require('./mode')\nconst VersionCheck = require('./version-check')\n\n// Generator polynomial used to encode version information\nconst G18 = (1 << 12) | (1 << 11) | (1 << 10) | (1 << 9) | (1 << 8) | (1 << 5) | (1 << 2) | (1 << 0)\nconst G18_BCH = Utils.getBCHDigit(G18)\n\nfunction getBestVersionForDataLength (mode, length, errorCorrectionLevel) {\n for (let currentVersion = 1; currentVersion <= 40; currentVersion++) {\n if (length <= exports.getCapacity(currentVersion, errorCorrectionLevel, mode)) {\n return currentVersion\n }\n }\n\n return undefined\n}\n\nfunction getReservedBitsCount (mode, version) {\n // Character count indicator + mode indicator bits\n return Mode.getCharCountIndicator(mode, version) + 4\n}\n\nfunction getTotalBitsFromDataArray (segments, version) {\n let totalBits = 0\n\n segments.forEach(function (data) {\n const reservedBits = getReservedBitsCount(data.mode, version)\n totalBits += reservedBits + data.getBitsLength()\n })\n\n return totalBits\n}\n\nfunction getBestVersionForMixedData (segments, errorCorrectionLevel) {\n for (let currentVersion = 1; currentVersion <= 40; currentVersion++) {\n const length = getTotalBitsFromDataArray(segments, currentVersion)\n if (length <= exports.getCapacity(currentVersion, errorCorrectionLevel, Mode.MIXED)) {\n return currentVersion\n }\n }\n\n return undefined\n}\n\n/**\n * Returns version number from a value.\n * If value is not a valid version, returns defaultValue\n *\n * @param {Number|String} value QR Code version\n * @param {Number} defaultValue Fallback value\n * @return {Number} QR Code version number\n */\nexports.from = function from (value, defaultValue) {\n if (VersionCheck.isValid(value)) {\n return parseInt(value, 10)\n }\n\n return defaultValue\n}\n\n/**\n * Returns how much data can be stored with the specified QR code version\n * and error correction level\n *\n * @param {Number} version QR Code version (1-40)\n * @param {Number} errorCorrectionLevel Error correction level\n * @param {Mode} mode Data mode\n * @return {Number} Quantity of storable data\n */\nexports.getCapacity = function getCapacity (version, errorCorrectionLevel, mode) {\n if (!VersionCheck.isValid(version)) {\n throw new Error('Invalid QR Code version')\n }\n\n // Use Byte mode as default\n if (typeof mode === 'undefined') mode = Mode.BYTE\n\n // Total codewords for this QR code version (Data + Error correction)\n const totalCodewords = Utils.getSymbolTotalCodewords(version)\n\n // Total number of error correction codewords\n const ecTotalCodewords = ECCode.getTotalCodewordsCount(version, errorCorrectionLevel)\n\n // Total number of data codewords\n const dataTotalCodewordsBits = (totalCodewords - ecTotalCodewords) * 8\n\n if (mode === Mode.MIXED) return dataTotalCodewordsBits\n\n const usableBits = dataTotalCodewordsBits - getReservedBitsCount(mode, version)\n\n // Return max number of storable codewords\n switch (mode) {\n case Mode.NUMERIC:\n return Math.floor((usableBits / 10) * 3)\n\n case Mode.ALPHANUMERIC:\n return Math.floor((usableBits / 11) * 2)\n\n case Mode.KANJI:\n return Math.floor(usableBits / 13)\n\n case Mode.BYTE:\n default:\n return Math.floor(usableBits / 8)\n }\n}\n\n/**\n * Returns the minimum version needed to contain the amount of data\n *\n * @param {Segment} data Segment of data\n * @param {Number} [errorCorrectionLevel=H] Error correction level\n * @param {Mode} mode Data mode\n * @return {Number} QR Code version\n */\nexports.getBestVersionForData = function getBestVersionForData (data, errorCorrectionLevel) {\n let seg\n\n const ecl = ECLevel.from(errorCorrectionLevel, ECLevel.M)\n\n if (Array.isArray(data)) {\n if (data.length > 1) {\n return getBestVersionForMixedData(data, ecl)\n }\n\n if (data.length === 0) {\n return 1\n }\n\n seg = data[0]\n } else {\n seg = data\n }\n\n return getBestVersionForDataLength(seg.mode, seg.getLength(), ecl)\n}\n\n/**\n * Returns version information with relative error correction bits\n *\n * The version information is included in QR Code symbols of version 7 or larger.\n * It consists of an 18-bit sequence containing 6 data bits,\n * with 12 error correction bits calculated using the (18, 6) Golay code.\n *\n * @param {Number} version QR Code version\n * @return {Number} Encoded version info bits\n */\nexports.getEncodedBits = function getEncodedBits (version) {\n if (!VersionCheck.isValid(version) || version < 7) {\n throw new Error('Invalid QR Code version')\n }\n\n let d = version << 12\n\n while (Utils.getBCHDigit(d) - G18_BCH >= 0) {\n d ^= (G18 << (Utils.getBCHDigit(d) - G18_BCH))\n }\n\n return (version << 12) | d\n}\n","const Utils = require('./utils')\n\nfunction clearCanvas (ctx, canvas, size) {\n ctx.clearRect(0, 0, canvas.width, canvas.height)\n\n if (!canvas.style) canvas.style = {}\n canvas.height = size\n canvas.width = size\n canvas.style.height = size + 'px'\n canvas.style.width = size + 'px'\n}\n\nfunction getCanvasElement () {\n try {\n return document.createElement('canvas')\n } catch (e) {\n throw new Error('You need to specify a canvas element')\n }\n}\n\nexports.render = function render (qrData, canvas, options) {\n let opts = options\n let canvasEl = canvas\n\n if (typeof opts === 'undefined' && (!canvas || !canvas.getContext)) {\n opts = canvas\n canvas = undefined\n }\n\n if (!canvas) {\n canvasEl = getCanvasElement()\n }\n\n opts = Utils.getOptions(opts)\n const size = Utils.getImageWidth(qrData.modules.size, opts)\n\n const ctx = canvasEl.getContext('2d')\n const image = ctx.createImageData(size, size)\n Utils.qrToImageData(image.data, qrData, opts)\n\n clearCanvas(ctx, canvasEl, size)\n ctx.putImageData(image, 0, 0)\n\n return canvasEl\n}\n\nexports.renderToDataURL = function renderToDataURL (qrData, canvas, options) {\n let opts = options\n\n if (typeof opts === 'undefined' && (!canvas || !canvas.getContext)) {\n opts = canvas\n canvas = undefined\n }\n\n if (!opts) opts = {}\n\n const canvasEl = exports.render(qrData, canvas, opts)\n\n const type = opts.type || 'image/png'\n const rendererOpts = opts.rendererOpts || {}\n\n return canvasEl.toDataURL(type, rendererOpts.quality)\n}\n","const Utils = require('./utils')\n\nfunction getColorAttrib (color, attrib) {\n const alpha = color.a / 255\n const str = attrib + '=\"' + color.hex + '\"'\n\n return alpha < 1\n ? str + ' ' + attrib + '-opacity=\"' + alpha.toFixed(2).slice(1) + '\"'\n : str\n}\n\nfunction svgCmd (cmd, x, y) {\n let str = cmd + x\n if (typeof y !== 'undefined') str += ' ' + y\n\n return str\n}\n\nfunction qrToPath (data, size, margin) {\n let path = ''\n let moveBy = 0\n let newRow = false\n let lineLength = 0\n\n for (let i = 0; i < data.length; i++) {\n const col = Math.floor(i % size)\n const row = Math.floor(i / size)\n\n if (!col && !newRow) newRow = true\n\n if (data[i]) {\n lineLength++\n\n if (!(i > 0 && col > 0 && data[i - 1])) {\n path += newRow\n ? svgCmd('M', col + margin, 0.5 + row + margin)\n : svgCmd('m', moveBy, 0)\n\n moveBy = 0\n newRow = false\n }\n\n if (!(col + 1 < size && data[i + 1])) {\n path += svgCmd('h', lineLength)\n lineLength = 0\n }\n } else {\n moveBy++\n }\n }\n\n return path\n}\n\nexports.render = function render (qrData, options, cb) {\n const opts = Utils.getOptions(options)\n const size = qrData.modules.size\n const data = qrData.modules.data\n const qrcodesize = size + opts.margin * 2\n\n const bg = !opts.color.light.a\n ? ''\n : ' '\n\n const path =\n ' '\n\n const viewBox = 'viewBox=\"' + '0 0 ' + qrcodesize + ' ' + qrcodesize + '\"'\n\n const width = !opts.width ? '' : 'width=\"' + opts.width + '\" height=\"' + opts.width + '\" '\n\n const svgTag = '' + bg + path + ' \\n'\n\n if (typeof cb === 'function') {\n cb(null, svgTag)\n }\n\n return svgTag\n}\n","function hex2rgba (hex) {\n if (typeof hex === 'number') {\n hex = hex.toString()\n }\n\n if (typeof hex !== 'string') {\n throw new Error('Color should be defined as hex string')\n }\n\n let hexCode = hex.slice().replace('#', '').split('')\n if (hexCode.length < 3 || hexCode.length === 5 || hexCode.length > 8) {\n throw new Error('Invalid hex color: ' + hex)\n }\n\n // Convert from short to long form (fff -> ffffff)\n if (hexCode.length === 3 || hexCode.length === 4) {\n hexCode = Array.prototype.concat.apply([], hexCode.map(function (c) {\n return [c, c]\n }))\n }\n\n // Add default alpha value\n if (hexCode.length === 6) hexCode.push('F', 'F')\n\n const hexValue = parseInt(hexCode.join(''), 16)\n\n return {\n r: (hexValue >> 24) & 255,\n g: (hexValue >> 16) & 255,\n b: (hexValue >> 8) & 255,\n a: hexValue & 255,\n hex: '#' + hexCode.slice(0, 6).join('')\n }\n}\n\nexports.getOptions = function getOptions (options) {\n if (!options) options = {}\n if (!options.color) options.color = {}\n\n const margin = typeof options.margin === 'undefined' ||\n options.margin === null ||\n options.margin < 0\n ? 4\n : options.margin\n\n const width = options.width && options.width >= 21 ? options.width : undefined\n const scale = options.scale || 4\n\n return {\n width: width,\n scale: width ? 4 : scale,\n margin: margin,\n color: {\n dark: hex2rgba(options.color.dark || '#000000ff'),\n light: hex2rgba(options.color.light || '#ffffffff')\n },\n type: options.type,\n rendererOpts: options.rendererOpts || {}\n }\n}\n\nexports.getScale = function getScale (qrSize, opts) {\n return opts.width && opts.width >= qrSize + opts.margin * 2\n ? opts.width / (qrSize + opts.margin * 2)\n : opts.scale\n}\n\nexports.getImageWidth = function getImageWidth (qrSize, opts) {\n const scale = exports.getScale(qrSize, opts)\n return Math.floor((qrSize + opts.margin * 2) * scale)\n}\n\nexports.qrToImageData = function qrToImageData (imgData, qr, opts) {\n const size = qr.modules.size\n const data = qr.modules.data\n const scale = exports.getScale(size, opts)\n const symbolSize = Math.floor((size + opts.margin * 2) * scale)\n const scaledMargin = opts.margin * scale\n const palette = [opts.color.light, opts.color.dark]\n\n for (let i = 0; i < symbolSize; i++) {\n for (let j = 0; j < symbolSize; j++) {\n let posDst = (i * symbolSize + j) * 4\n let pxColor = opts.color.light\n\n if (i >= scaledMargin && j >= scaledMargin &&\n i < symbolSize - scaledMargin && j < symbolSize - scaledMargin) {\n const iSrc = Math.floor((i - scaledMargin) / scale)\n const jSrc = Math.floor((j - scaledMargin) / scale)\n pxColor = palette[data[iSrc * size + jSrc] ? 1 : 0]\n }\n\n imgData[posDst++] = pxColor.r\n imgData[posDst++] = pxColor.g\n imgData[posDst++] = pxColor.b\n imgData[posDst] = pxColor.a\n }\n }\n}\n","/**\n * @license React\n * react-dom.production.min.js\n *\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n/*\n Modernizr 3.0.0pre (Custom Build) | MIT\n*/\n'use strict';var aa=require(\"react\"),ca=require(\"scheduler\");function p(a){for(var b=\"https://reactjs.org/docs/error-decoder.html?invariant=\"+a,c=1;cb}return!1}function v(a,b,c,d,e,f,g){this.acceptsBooleans=2===b||3===b||4===b;this.attributeName=d;this.attributeNamespace=e;this.mustUseProperty=c;this.propertyName=a;this.type=b;this.sanitizeURL=f;this.removeEmptyString=g}var z={};\n\"children dangerouslySetInnerHTML defaultValue defaultChecked innerHTML suppressContentEditableWarning suppressHydrationWarning style\".split(\" \").forEach(function(a){z[a]=new v(a,0,!1,a,null,!1,!1)});[[\"acceptCharset\",\"accept-charset\"],[\"className\",\"class\"],[\"htmlFor\",\"for\"],[\"httpEquiv\",\"http-equiv\"]].forEach(function(a){var b=a[0];z[b]=new v(b,1,!1,a[1],null,!1,!1)});[\"contentEditable\",\"draggable\",\"spellCheck\",\"value\"].forEach(function(a){z[a]=new v(a,2,!1,a.toLowerCase(),null,!1,!1)});\n[\"autoReverse\",\"externalResourcesRequired\",\"focusable\",\"preserveAlpha\"].forEach(function(a){z[a]=new v(a,2,!1,a,null,!1,!1)});\"allowFullScreen async autoFocus autoPlay controls default defer disabled disablePictureInPicture disableRemotePlayback formNoValidate hidden loop noModule noValidate open playsInline readOnly required reversed scoped seamless itemScope\".split(\" \").forEach(function(a){z[a]=new v(a,3,!1,a.toLowerCase(),null,!1,!1)});\n[\"checked\",\"multiple\",\"muted\",\"selected\"].forEach(function(a){z[a]=new v(a,3,!0,a,null,!1,!1)});[\"capture\",\"download\"].forEach(function(a){z[a]=new v(a,4,!1,a,null,!1,!1)});[\"cols\",\"rows\",\"size\",\"span\"].forEach(function(a){z[a]=new v(a,6,!1,a,null,!1,!1)});[\"rowSpan\",\"start\"].forEach(function(a){z[a]=new v(a,5,!1,a.toLowerCase(),null,!1,!1)});var ra=/[\\-:]([a-z])/g;function sa(a){return a[1].toUpperCase()}\n\"accent-height alignment-baseline arabic-form baseline-shift cap-height clip-path clip-rule color-interpolation color-interpolation-filters color-profile color-rendering dominant-baseline enable-background fill-opacity fill-rule flood-color flood-opacity font-family font-size font-size-adjust font-stretch font-style font-variant font-weight glyph-name glyph-orientation-horizontal glyph-orientation-vertical horiz-adv-x horiz-origin-x image-rendering letter-spacing lighting-color marker-end marker-mid marker-start overline-position overline-thickness paint-order panose-1 pointer-events rendering-intent shape-rendering stop-color stop-opacity strikethrough-position strikethrough-thickness stroke-dasharray stroke-dashoffset stroke-linecap stroke-linejoin stroke-miterlimit stroke-opacity stroke-width text-anchor text-decoration text-rendering underline-position underline-thickness unicode-bidi unicode-range units-per-em v-alphabetic v-hanging v-ideographic v-mathematical vector-effect vert-adv-y vert-origin-x vert-origin-y word-spacing writing-mode xmlns:xlink x-height\".split(\" \").forEach(function(a){var b=a.replace(ra,\nsa);z[b]=new v(b,1,!1,a,null,!1,!1)});\"xlink:actuate xlink:arcrole xlink:role xlink:show xlink:title xlink:type\".split(\" \").forEach(function(a){var b=a.replace(ra,sa);z[b]=new v(b,1,!1,a,\"http://www.w3.org/1999/xlink\",!1,!1)});[\"xml:base\",\"xml:lang\",\"xml:space\"].forEach(function(a){var b=a.replace(ra,sa);z[b]=new v(b,1,!1,a,\"http://www.w3.org/XML/1998/namespace\",!1,!1)});[\"tabIndex\",\"crossOrigin\"].forEach(function(a){z[a]=new v(a,1,!1,a.toLowerCase(),null,!1,!1)});\nz.xlinkHref=new v(\"xlinkHref\",1,!1,\"xlink:href\",\"http://www.w3.org/1999/xlink\",!0,!1);[\"src\",\"href\",\"action\",\"formAction\"].forEach(function(a){z[a]=new v(a,1,!1,a.toLowerCase(),null,!0,!0)});\nfunction ta(a,b,c,d){var e=z.hasOwnProperty(b)?z[b]:null;if(null!==e?0!==e.type:d||!(2h||e[g]!==f[h]){var k=\"\\n\"+e[g].replace(\" at new \",\" at \");a.displayName&&k.includes(\"\")&&(k=k.replace(\"\",a.displayName));return k}while(1<=g&&0<=h)}break}}}finally{Na=!1,Error.prepareStackTrace=c}return(a=a?a.displayName||a.name:\"\")?Ma(a):\"\"}\nfunction Pa(a){switch(a.tag){case 5:return Ma(a.type);case 16:return Ma(\"Lazy\");case 13:return Ma(\"Suspense\");case 19:return Ma(\"SuspenseList\");case 0:case 2:case 15:return a=Oa(a.type,!1),a;case 11:return a=Oa(a.type.render,!1),a;case 1:return a=Oa(a.type,!0),a;default:return\"\"}}\nfunction Qa(a){if(null==a)return null;if(\"function\"===typeof a)return a.displayName||a.name||null;if(\"string\"===typeof a)return a;switch(a){case ya:return\"Fragment\";case wa:return\"Portal\";case Aa:return\"Profiler\";case za:return\"StrictMode\";case Ea:return\"Suspense\";case Fa:return\"SuspenseList\"}if(\"object\"===typeof a)switch(a.$$typeof){case Ca:return(a.displayName||\"Context\")+\".Consumer\";case Ba:return(a._context.displayName||\"Context\")+\".Provider\";case Da:var b=a.render;a=a.displayName;a||(a=b.displayName||\nb.name||\"\",a=\"\"!==a?\"ForwardRef(\"+a+\")\":\"ForwardRef\");return a;case Ga:return b=a.displayName||null,null!==b?b:Qa(a.type)||\"Memo\";case Ha:b=a._payload;a=a._init;try{return Qa(a(b))}catch(c){}}return null}\nfunction Ra(a){var b=a.type;switch(a.tag){case 24:return\"Cache\";case 9:return(b.displayName||\"Context\")+\".Consumer\";case 10:return(b._context.displayName||\"Context\")+\".Provider\";case 18:return\"DehydratedFragment\";case 11:return a=b.render,a=a.displayName||a.name||\"\",b.displayName||(\"\"!==a?\"ForwardRef(\"+a+\")\":\"ForwardRef\");case 7:return\"Fragment\";case 5:return b;case 4:return\"Portal\";case 3:return\"Root\";case 6:return\"Text\";case 16:return Qa(b);case 8:return b===za?\"StrictMode\":\"Mode\";case 22:return\"Offscreen\";\ncase 12:return\"Profiler\";case 21:return\"Scope\";case 13:return\"Suspense\";case 19:return\"SuspenseList\";case 25:return\"TracingMarker\";case 1:case 0:case 17:case 2:case 14:case 15:if(\"function\"===typeof b)return b.displayName||b.name||null;if(\"string\"===typeof b)return b}return null}function Sa(a){switch(typeof a){case \"boolean\":case \"number\":case \"string\":case \"undefined\":return a;case \"object\":return a;default:return\"\"}}\nfunction Ta(a){var b=a.type;return(a=a.nodeName)&&\"input\"===a.toLowerCase()&&(\"checkbox\"===b||\"radio\"===b)}\nfunction Ua(a){var b=Ta(a)?\"checked\":\"value\",c=Object.getOwnPropertyDescriptor(a.constructor.prototype,b),d=\"\"+a[b];if(!a.hasOwnProperty(b)&&\"undefined\"!==typeof c&&\"function\"===typeof c.get&&\"function\"===typeof c.set){var e=c.get,f=c.set;Object.defineProperty(a,b,{configurable:!0,get:function(){return e.call(this)},set:function(a){d=\"\"+a;f.call(this,a)}});Object.defineProperty(a,b,{enumerable:c.enumerable});return{getValue:function(){return d},setValue:function(a){d=\"\"+a},stopTracking:function(){a._valueTracker=\nnull;delete a[b]}}}}function Va(a){a._valueTracker||(a._valueTracker=Ua(a))}function Wa(a){if(!a)return!1;var b=a._valueTracker;if(!b)return!0;var c=b.getValue();var d=\"\";a&&(d=Ta(a)?a.checked?\"true\":\"false\":a.value);a=d;return a!==c?(b.setValue(a),!0):!1}function Xa(a){a=a||(\"undefined\"!==typeof document?document:void 0);if(\"undefined\"===typeof a)return null;try{return a.activeElement||a.body}catch(b){return a.body}}\nfunction Ya(a,b){var c=b.checked;return A({},b,{defaultChecked:void 0,defaultValue:void 0,value:void 0,checked:null!=c?c:a._wrapperState.initialChecked})}function Za(a,b){var c=null==b.defaultValue?\"\":b.defaultValue,d=null!=b.checked?b.checked:b.defaultChecked;c=Sa(null!=b.value?b.value:c);a._wrapperState={initialChecked:d,initialValue:c,controlled:\"checkbox\"===b.type||\"radio\"===b.type?null!=b.checked:null!=b.value}}function ab(a,b){b=b.checked;null!=b&&ta(a,\"checked\",b,!1)}\nfunction bb(a,b){ab(a,b);var c=Sa(b.value),d=b.type;if(null!=c)if(\"number\"===d){if(0===c&&\"\"===a.value||a.value!=c)a.value=\"\"+c}else a.value!==\"\"+c&&(a.value=\"\"+c);else if(\"submit\"===d||\"reset\"===d){a.removeAttribute(\"value\");return}b.hasOwnProperty(\"value\")?cb(a,b.type,c):b.hasOwnProperty(\"defaultValue\")&&cb(a,b.type,Sa(b.defaultValue));null==b.checked&&null!=b.defaultChecked&&(a.defaultChecked=!!b.defaultChecked)}\nfunction db(a,b,c){if(b.hasOwnProperty(\"value\")||b.hasOwnProperty(\"defaultValue\")){var d=b.type;if(!(\"submit\"!==d&&\"reset\"!==d||void 0!==b.value&&null!==b.value))return;b=\"\"+a._wrapperState.initialValue;c||b===a.value||(a.value=b);a.defaultValue=b}c=a.name;\"\"!==c&&(a.name=\"\");a.defaultChecked=!!a._wrapperState.initialChecked;\"\"!==c&&(a.name=c)}\nfunction cb(a,b,c){if(\"number\"!==b||Xa(a.ownerDocument)!==a)null==c?a.defaultValue=\"\"+a._wrapperState.initialValue:a.defaultValue!==\"\"+c&&(a.defaultValue=\"\"+c)}var eb=Array.isArray;\nfunction fb(a,b,c,d){a=a.options;if(b){b={};for(var e=0;e\"+b.valueOf().toString()+\"\";for(b=mb.firstChild;a.firstChild;)a.removeChild(a.firstChild);for(;b.firstChild;)a.appendChild(b.firstChild)}});\nfunction ob(a,b){if(b){var c=a.firstChild;if(c&&c===a.lastChild&&3===c.nodeType){c.nodeValue=b;return}}a.textContent=b}\nvar pb={animationIterationCount:!0,aspectRatio:!0,borderImageOutset:!0,borderImageSlice:!0,borderImageWidth:!0,boxFlex:!0,boxFlexGroup:!0,boxOrdinalGroup:!0,columnCount:!0,columns:!0,flex:!0,flexGrow:!0,flexPositive:!0,flexShrink:!0,flexNegative:!0,flexOrder:!0,gridArea:!0,gridRow:!0,gridRowEnd:!0,gridRowSpan:!0,gridRowStart:!0,gridColumn:!0,gridColumnEnd:!0,gridColumnSpan:!0,gridColumnStart:!0,fontWeight:!0,lineClamp:!0,lineHeight:!0,opacity:!0,order:!0,orphans:!0,tabSize:!0,widows:!0,zIndex:!0,\nzoom:!0,fillOpacity:!0,floodOpacity:!0,stopOpacity:!0,strokeDasharray:!0,strokeDashoffset:!0,strokeMiterlimit:!0,strokeOpacity:!0,strokeWidth:!0},qb=[\"Webkit\",\"ms\",\"Moz\",\"O\"];Object.keys(pb).forEach(function(a){qb.forEach(function(b){b=b+a.charAt(0).toUpperCase()+a.substring(1);pb[b]=pb[a]})});function rb(a,b,c){return null==b||\"boolean\"===typeof b||\"\"===b?\"\":c||\"number\"!==typeof b||0===b||pb.hasOwnProperty(a)&&pb[a]?(\"\"+b).trim():b+\"px\"}\nfunction sb(a,b){a=a.style;for(var c in b)if(b.hasOwnProperty(c)){var d=0===c.indexOf(\"--\"),e=rb(c,b[c],d);\"float\"===c&&(c=\"cssFloat\");d?a.setProperty(c,e):a[c]=e}}var tb=A({menuitem:!0},{area:!0,base:!0,br:!0,col:!0,embed:!0,hr:!0,img:!0,input:!0,keygen:!0,link:!0,meta:!0,param:!0,source:!0,track:!0,wbr:!0});\nfunction ub(a,b){if(b){if(tb[a]&&(null!=b.children||null!=b.dangerouslySetInnerHTML))throw Error(p(137,a));if(null!=b.dangerouslySetInnerHTML){if(null!=b.children)throw Error(p(60));if(\"object\"!==typeof b.dangerouslySetInnerHTML||!(\"__html\"in b.dangerouslySetInnerHTML))throw Error(p(61));}if(null!=b.style&&\"object\"!==typeof b.style)throw Error(p(62));}}\nfunction vb(a,b){if(-1===a.indexOf(\"-\"))return\"string\"===typeof b.is;switch(a){case \"annotation-xml\":case \"color-profile\":case \"font-face\":case \"font-face-src\":case \"font-face-uri\":case \"font-face-format\":case \"font-face-name\":case \"missing-glyph\":return!1;default:return!0}}var wb=null;function xb(a){a=a.target||a.srcElement||window;a.correspondingUseElement&&(a=a.correspondingUseElement);return 3===a.nodeType?a.parentNode:a}var yb=null,zb=null,Ab=null;\nfunction Bb(a){if(a=Cb(a)){if(\"function\"!==typeof yb)throw Error(p(280));var b=a.stateNode;b&&(b=Db(b),yb(a.stateNode,a.type,b))}}function Eb(a){zb?Ab?Ab.push(a):Ab=[a]:zb=a}function Fb(){if(zb){var a=zb,b=Ab;Ab=zb=null;Bb(a);if(b)for(a=0;a>>=0;return 0===a?32:31-(pc(a)/qc|0)|0}var rc=64,sc=4194304;\nfunction tc(a){switch(a&-a){case 1:return 1;case 2:return 2;case 4:return 4;case 8:return 8;case 16:return 16;case 32:return 32;case 64:case 128:case 256:case 512:case 1024:case 2048:case 4096:case 8192:case 16384:case 32768:case 65536:case 131072:case 262144:case 524288:case 1048576:case 2097152:return a&4194240;case 4194304:case 8388608:case 16777216:case 33554432:case 67108864:return a&130023424;case 134217728:return 134217728;case 268435456:return 268435456;case 536870912:return 536870912;case 1073741824:return 1073741824;\ndefault:return a}}function uc(a,b){var c=a.pendingLanes;if(0===c)return 0;var d=0,e=a.suspendedLanes,f=a.pingedLanes,g=c&268435455;if(0!==g){var h=g&~e;0!==h?d=tc(h):(f&=g,0!==f&&(d=tc(f)))}else g=c&~e,0!==g?d=tc(g):0!==f&&(d=tc(f));if(0===d)return 0;if(0!==b&&b!==d&&0===(b&e)&&(e=d&-d,f=b&-b,e>=f||16===e&&0!==(f&4194240)))return b;0!==(d&4)&&(d|=c&16);b=a.entangledLanes;if(0!==b)for(a=a.entanglements,b&=d;0c;c++)b.push(a);return b}\nfunction Ac(a,b,c){a.pendingLanes|=b;536870912!==b&&(a.suspendedLanes=0,a.pingedLanes=0);a=a.eventTimes;b=31-oc(b);a[b]=c}function Bc(a,b){var c=a.pendingLanes&~b;a.pendingLanes=b;a.suspendedLanes=0;a.pingedLanes=0;a.expiredLanes&=b;a.mutableReadLanes&=b;a.entangledLanes&=b;b=a.entanglements;var d=a.eventTimes;for(a=a.expirationTimes;0=be),ee=String.fromCharCode(32),fe=!1;\nfunction ge(a,b){switch(a){case \"keyup\":return-1!==$d.indexOf(b.keyCode);case \"keydown\":return 229!==b.keyCode;case \"keypress\":case \"mousedown\":case \"focusout\":return!0;default:return!1}}function he(a){a=a.detail;return\"object\"===typeof a&&\"data\"in a?a.data:null}var ie=!1;function je(a,b){switch(a){case \"compositionend\":return he(b);case \"keypress\":if(32!==b.which)return null;fe=!0;return ee;case \"textInput\":return a=b.data,a===ee&&fe?null:a;default:return null}}\nfunction ke(a,b){if(ie)return\"compositionend\"===a||!ae&&ge(a,b)?(a=nd(),md=ld=kd=null,ie=!1,a):null;switch(a){case \"paste\":return null;case \"keypress\":if(!(b.ctrlKey||b.altKey||b.metaKey)||b.ctrlKey&&b.altKey){if(b.char&&1=b)return{node:c,offset:b-a};a=d}a:{for(;c;){if(c.nextSibling){c=c.nextSibling;break a}c=c.parentNode}c=void 0}c=Je(c)}}function Le(a,b){return a&&b?a===b?!0:a&&3===a.nodeType?!1:b&&3===b.nodeType?Le(a,b.parentNode):\"contains\"in a?a.contains(b):a.compareDocumentPosition?!!(a.compareDocumentPosition(b)&16):!1:!1}\nfunction Me(){for(var a=window,b=Xa();b instanceof a.HTMLIFrameElement;){try{var c=\"string\"===typeof b.contentWindow.location.href}catch(d){c=!1}if(c)a=b.contentWindow;else break;b=Xa(a.document)}return b}function Ne(a){var b=a&&a.nodeName&&a.nodeName.toLowerCase();return b&&(\"input\"===b&&(\"text\"===a.type||\"search\"===a.type||\"tel\"===a.type||\"url\"===a.type||\"password\"===a.type)||\"textarea\"===b||\"true\"===a.contentEditable)}\nfunction Oe(a){var b=Me(),c=a.focusedElem,d=a.selectionRange;if(b!==c&&c&&c.ownerDocument&&Le(c.ownerDocument.documentElement,c)){if(null!==d&&Ne(c))if(b=d.start,a=d.end,void 0===a&&(a=b),\"selectionStart\"in c)c.selectionStart=b,c.selectionEnd=Math.min(a,c.value.length);else if(a=(b=c.ownerDocument||document)&&b.defaultView||window,a.getSelection){a=a.getSelection();var e=c.textContent.length,f=Math.min(d.start,e);d=void 0===d.end?f:Math.min(d.end,e);!a.extend&&f>d&&(e=d,d=f,f=e);e=Ke(c,f);var g=Ke(c,\nd);e&&g&&(1!==a.rangeCount||a.anchorNode!==e.node||a.anchorOffset!==e.offset||a.focusNode!==g.node||a.focusOffset!==g.offset)&&(b=b.createRange(),b.setStart(e.node,e.offset),a.removeAllRanges(),f>d?(a.addRange(b),a.extend(g.node,g.offset)):(b.setEnd(g.node,g.offset),a.addRange(b)))}b=[];for(a=c;a=a.parentNode;)1===a.nodeType&&b.push({element:a,left:a.scrollLeft,top:a.scrollTop});\"function\"===typeof c.focus&&c.focus();for(c=0;c=document.documentMode,Qe=null,Re=null,Se=null,Te=!1;\nfunction Ue(a,b,c){var d=c.window===c?c.document:9===c.nodeType?c:c.ownerDocument;Te||null==Qe||Qe!==Xa(d)||(d=Qe,\"selectionStart\"in d&&Ne(d)?d={start:d.selectionStart,end:d.selectionEnd}:(d=(d.ownerDocument&&d.ownerDocument.defaultView||window).getSelection(),d={anchorNode:d.anchorNode,anchorOffset:d.anchorOffset,focusNode:d.focusNode,focusOffset:d.focusOffset}),Se&&Ie(Se,d)||(Se=d,d=oe(Re,\"onSelect\"),0Tf||(a.current=Sf[Tf],Sf[Tf]=null,Tf--)}function G(a,b){Tf++;Sf[Tf]=a.current;a.current=b}var Vf={},H=Uf(Vf),Wf=Uf(!1),Xf=Vf;function Yf(a,b){var c=a.type.contextTypes;if(!c)return Vf;var d=a.stateNode;if(d&&d.__reactInternalMemoizedUnmaskedChildContext===b)return d.__reactInternalMemoizedMaskedChildContext;var e={},f;for(f in c)e[f]=b[f];d&&(a=a.stateNode,a.__reactInternalMemoizedUnmaskedChildContext=b,a.__reactInternalMemoizedMaskedChildContext=e);return e}\nfunction Zf(a){a=a.childContextTypes;return null!==a&&void 0!==a}function $f(){E(Wf);E(H)}function ag(a,b,c){if(H.current!==Vf)throw Error(p(168));G(H,b);G(Wf,c)}function bg(a,b,c){var d=a.stateNode;b=b.childContextTypes;if(\"function\"!==typeof d.getChildContext)return c;d=d.getChildContext();for(var e in d)if(!(e in b))throw Error(p(108,Ra(a)||\"Unknown\",e));return A({},c,d)}\nfunction cg(a){a=(a=a.stateNode)&&a.__reactInternalMemoizedMergedChildContext||Vf;Xf=H.current;G(H,a);G(Wf,Wf.current);return!0}function dg(a,b,c){var d=a.stateNode;if(!d)throw Error(p(169));c?(a=bg(a,b,Xf),d.__reactInternalMemoizedMergedChildContext=a,E(Wf),E(H),G(H,a)):E(Wf);G(Wf,c)}var eg=null,fg=!1,gg=!1;function hg(a){null===eg?eg=[a]:eg.push(a)}function ig(a){fg=!0;hg(a)}\nfunction jg(){if(!gg&&null!==eg){gg=!0;var a=0,b=C;try{var c=eg;for(C=1;a>=g;e-=g;rg=1<<32-oc(b)+e|c<w?(x=u,u=null):x=u.sibling;var n=r(e,u,h[w],k);if(null===n){null===u&&(u=x);break}a&&u&&null===n.alternate&&b(e,u);g=f(n,g,w);null===m?l=n:m.sibling=n;m=n;u=x}if(w===h.length)return c(e,u),I&&tg(e,w),l;if(null===u){for(;ww?(x=m,m=null):x=m.sibling;var t=r(e,m,n.value,k);if(null===t){null===m&&(m=x);break}a&&m&&null===t.alternate&&b(e,m);g=f(t,g,w);null===u?l=t:u.sibling=t;u=t;m=x}if(n.done)return c(e,\nm),I&&tg(e,w),l;if(null===m){for(;!n.done;w++,n=h.next())n=q(e,n.value,k),null!==n&&(g=f(n,g,w),null===u?l=n:u.sibling=n,u=n);I&&tg(e,w);return l}for(m=d(e,m);!n.done;w++,n=h.next())n=y(m,e,w,n.value,k),null!==n&&(a&&null!==n.alternate&&m.delete(null===n.key?w:n.key),g=f(n,g,w),null===u?l=n:u.sibling=n,u=n);a&&m.forEach(function(a){return b(e,a)});I&&tg(e,w);return l}function J(a,d,f,h){\"object\"===typeof f&&null!==f&&f.type===ya&&null===f.key&&(f=f.props.children);if(\"object\"===typeof f&&null!==f){switch(f.$$typeof){case va:a:{for(var k=\nf.key,l=d;null!==l;){if(l.key===k){k=f.type;if(k===ya){if(7===l.tag){c(a,l.sibling);d=e(l,f.props.children);d.return=a;a=d;break a}}else if(l.elementType===k||\"object\"===typeof k&&null!==k&&k.$$typeof===Ha&&uh(k)===l.type){c(a,l.sibling);d=e(l,f.props);d.ref=sh(a,l,f);d.return=a;a=d;break a}c(a,l);break}else b(a,l);l=l.sibling}f.type===ya?(d=Ah(f.props.children,a.mode,h,f.key),d.return=a,a=d):(h=yh(f.type,f.key,f.props,null,a.mode,h),h.ref=sh(a,d,f),h.return=a,a=h)}return g(a);case wa:a:{for(l=f.key;null!==\nd;){if(d.key===l)if(4===d.tag&&d.stateNode.containerInfo===f.containerInfo&&d.stateNode.implementation===f.implementation){c(a,d.sibling);d=e(d,f.children||[]);d.return=a;a=d;break a}else{c(a,d);break}else b(a,d);d=d.sibling}d=zh(f,a.mode,h);d.return=a;a=d}return g(a);case Ha:return l=f._init,J(a,d,l(f._payload),h)}if(eb(f))return n(a,d,f,h);if(Ka(f))return t(a,d,f,h);th(a,f)}return\"string\"===typeof f&&\"\"!==f||\"number\"===typeof f?(f=\"\"+f,null!==d&&6===d.tag?(c(a,d.sibling),d=e(d,f),d.return=a,a=d):\n(c(a,d),d=xh(f,a.mode,h),d.return=a,a=d),g(a)):c(a,d)}return J}var Bh=vh(!0),Ch=vh(!1),Dh={},Eh=Uf(Dh),Fh=Uf(Dh),Gh=Uf(Dh);function Hh(a){if(a===Dh)throw Error(p(174));return a}function Ih(a,b){G(Gh,b);G(Fh,a);G(Eh,Dh);a=b.nodeType;switch(a){case 9:case 11:b=(b=b.documentElement)?b.namespaceURI:lb(null,\"\");break;default:a=8===a?b.parentNode:b,b=a.namespaceURI||null,a=a.tagName,b=lb(b,a)}E(Eh);G(Eh,b)}function Jh(){E(Eh);E(Fh);E(Gh)}\nfunction Kh(a){Hh(Gh.current);var b=Hh(Eh.current);var c=lb(b,a.type);b!==c&&(G(Fh,a),G(Eh,c))}function Lh(a){Fh.current===a&&(E(Eh),E(Fh))}var M=Uf(0);\nfunction Mh(a){for(var b=a;null!==b;){if(13===b.tag){var c=b.memoizedState;if(null!==c&&(c=c.dehydrated,null===c||\"$?\"===c.data||\"$!\"===c.data))return b}else if(19===b.tag&&void 0!==b.memoizedProps.revealOrder){if(0!==(b.flags&128))return b}else if(null!==b.child){b.child.return=b;b=b.child;continue}if(b===a)break;for(;null===b.sibling;){if(null===b.return||b.return===a)return null;b=b.return}b.sibling.return=b.return;b=b.sibling}return null}var Nh=[];\nfunction Oh(){for(var a=0;ac?c:4;a(!0);var d=Qh.transition;Qh.transition={};try{a(!1),b()}finally{C=c,Qh.transition=d}}function Fi(){return di().memoizedState}\nfunction Gi(a,b,c){var d=lh(a);c={lane:d,action:c,hasEagerState:!1,eagerState:null,next:null};if(Hi(a))Ii(b,c);else if(c=Yg(a,b,c,d),null!==c){var e=L();mh(c,a,d,e);Ji(c,b,d)}}\nfunction ri(a,b,c){var d=lh(a),e={lane:d,action:c,hasEagerState:!1,eagerState:null,next:null};if(Hi(a))Ii(b,e);else{var f=a.alternate;if(0===a.lanes&&(null===f||0===f.lanes)&&(f=b.lastRenderedReducer,null!==f))try{var g=b.lastRenderedState,h=f(g,c);e.hasEagerState=!0;e.eagerState=h;if(He(h,g)){var k=b.interleaved;null===k?(e.next=e,Xg(b)):(e.next=k.next,k.next=e);b.interleaved=e;return}}catch(l){}finally{}c=Yg(a,b,e,d);null!==c&&(e=L(),mh(c,a,d,e),Ji(c,b,d))}}\nfunction Hi(a){var b=a.alternate;return a===N||null!==b&&b===N}function Ii(a,b){Th=Sh=!0;var c=a.pending;null===c?b.next=b:(b.next=c.next,c.next=b);a.pending=b}function Ji(a,b,c){if(0!==(c&4194240)){var d=b.lanes;d&=a.pendingLanes;c|=d;b.lanes=c;Cc(a,c)}}\nvar ai={readContext:Vg,useCallback:Q,useContext:Q,useEffect:Q,useImperativeHandle:Q,useInsertionEffect:Q,useLayoutEffect:Q,useMemo:Q,useReducer:Q,useRef:Q,useState:Q,useDebugValue:Q,useDeferredValue:Q,useTransition:Q,useMutableSource:Q,useSyncExternalStore:Q,useId:Q,unstable_isNewReconciler:!1},Yh={readContext:Vg,useCallback:function(a,b){ci().memoizedState=[a,void 0===b?null:b];return a},useContext:Vg,useEffect:vi,useImperativeHandle:function(a,b,c){c=null!==c&&void 0!==c?c.concat([a]):null;return ti(4194308,\n4,yi.bind(null,b,a),c)},useLayoutEffect:function(a,b){return ti(4194308,4,a,b)},useInsertionEffect:function(a,b){return ti(4,2,a,b)},useMemo:function(a,b){var c=ci();b=void 0===b?null:b;a=a();c.memoizedState=[a,b];return a},useReducer:function(a,b,c){var d=ci();b=void 0!==c?c(b):b;d.memoizedState=d.baseState=b;a={pending:null,interleaved:null,lanes:0,dispatch:null,lastRenderedReducer:a,lastRenderedState:b};d.queue=a;a=a.dispatch=Gi.bind(null,N,a);return[d.memoizedState,a]},useRef:function(a){var b=\nci();a={current:a};return b.memoizedState=a},useState:qi,useDebugValue:Ai,useDeferredValue:function(a){return ci().memoizedState=a},useTransition:function(){var a=qi(!1),b=a[0];a=Ei.bind(null,a[1]);ci().memoizedState=a;return[b,a]},useMutableSource:function(){},useSyncExternalStore:function(a,b,c){var d=N,e=ci();if(I){if(void 0===c)throw Error(p(407));c=c()}else{c=b();if(null===R)throw Error(p(349));0!==(Rh&30)||ni(d,b,c)}e.memoizedState=c;var f={value:c,getSnapshot:b};e.queue=f;vi(ki.bind(null,d,\nf,a),[a]);d.flags|=2048;li(9,mi.bind(null,d,f,c,b),void 0,null);return c},useId:function(){var a=ci(),b=R.identifierPrefix;if(I){var c=sg;var d=rg;c=(d&~(1<<32-oc(d)-1)).toString(32)+c;b=\":\"+b+\"R\"+c;c=Uh++;0\\x3c/script>\",a=a.removeChild(a.firstChild)):\n\"string\"===typeof d.is?a=g.createElement(c,{is:d.is}):(a=g.createElement(c),\"select\"===c&&(g=a,d.multiple?g.multiple=!0:d.size&&(g.size=d.size))):a=g.createElementNS(a,c);a[Of]=b;a[Pf]=d;Aj(a,b,!1,!1);b.stateNode=a;a:{g=vb(c,d);switch(c){case \"dialog\":D(\"cancel\",a);D(\"close\",a);e=d;break;case \"iframe\":case \"object\":case \"embed\":D(\"load\",a);e=d;break;case \"video\":case \"audio\":for(e=0;eHj&&(b.flags|=128,d=!0,Ej(f,!1),b.lanes=4194304)}else{if(!d)if(a=Mh(g),null!==a){if(b.flags|=128,d=!0,c=a.updateQueue,null!==c&&(b.updateQueue=c,b.flags|=4),Ej(f,!0),null===f.tail&&\"hidden\"===f.tailMode&&!g.alternate&&!I)return S(b),null}else 2*B()-f.renderingStartTime>Hj&&1073741824!==c&&(b.flags|=128,d=!0,Ej(f,!1),b.lanes=4194304);f.isBackwards?(g.sibling=b.child,b.child=g):(c=f.last,null!==c?c.sibling=g:b.child=g,f.last=g)}if(null!==f.tail)return b=f.tail,f.rendering=\nb,f.tail=b.sibling,f.renderingStartTime=B(),b.sibling=null,c=M.current,G(M,d?c&1|2:c&1),b;S(b);return null;case 22:case 23:return Ij(),d=null!==b.memoizedState,null!==a&&null!==a.memoizedState!==d&&(b.flags|=8192),d&&0!==(b.mode&1)?0!==(gj&1073741824)&&(S(b),b.subtreeFlags&6&&(b.flags|=8192)):S(b),null;case 24:return null;case 25:return null}throw Error(p(156,b.tag));}\nfunction Jj(a,b){wg(b);switch(b.tag){case 1:return Zf(b.type)&&$f(),a=b.flags,a&65536?(b.flags=a&-65537|128,b):null;case 3:return Jh(),E(Wf),E(H),Oh(),a=b.flags,0!==(a&65536)&&0===(a&128)?(b.flags=a&-65537|128,b):null;case 5:return Lh(b),null;case 13:E(M);a=b.memoizedState;if(null!==a&&null!==a.dehydrated){if(null===b.alternate)throw Error(p(340));Ig()}a=b.flags;return a&65536?(b.flags=a&-65537|128,b):null;case 19:return E(M),null;case 4:return Jh(),null;case 10:return Rg(b.type._context),null;case 22:case 23:return Ij(),\nnull;case 24:return null;default:return null}}var Kj=!1,U=!1,Lj=\"function\"===typeof WeakSet?WeakSet:Set,V=null;function Mj(a,b){var c=a.ref;if(null!==c)if(\"function\"===typeof c)try{c(null)}catch(d){W(a,b,d)}else c.current=null}function Nj(a,b,c){try{c()}catch(d){W(a,b,d)}}var Oj=!1;\nfunction Pj(a,b){Cf=dd;a=Me();if(Ne(a)){if(\"selectionStart\"in a)var c={start:a.selectionStart,end:a.selectionEnd};else a:{c=(c=a.ownerDocument)&&c.defaultView||window;var d=c.getSelection&&c.getSelection();if(d&&0!==d.rangeCount){c=d.anchorNode;var e=d.anchorOffset,f=d.focusNode;d=d.focusOffset;try{c.nodeType,f.nodeType}catch(F){c=null;break a}var g=0,h=-1,k=-1,l=0,m=0,q=a,r=null;b:for(;;){for(var y;;){q!==c||0!==e&&3!==q.nodeType||(h=g+e);q!==f||0!==d&&3!==q.nodeType||(k=g+d);3===q.nodeType&&(g+=\nq.nodeValue.length);if(null===(y=q.firstChild))break;r=q;q=y}for(;;){if(q===a)break b;r===c&&++l===e&&(h=g);r===f&&++m===d&&(k=g);if(null!==(y=q.nextSibling))break;q=r;r=q.parentNode}q=y}c=-1===h||-1===k?null:{start:h,end:k}}else c=null}c=c||{start:0,end:0}}else c=null;Df={focusedElem:a,selectionRange:c};dd=!1;for(V=b;null!==V;)if(b=V,a=b.child,0!==(b.subtreeFlags&1028)&&null!==a)a.return=b,V=a;else for(;null!==V;){b=V;try{var n=b.alternate;if(0!==(b.flags&1024))switch(b.tag){case 0:case 11:case 15:break;\ncase 1:if(null!==n){var t=n.memoizedProps,J=n.memoizedState,x=b.stateNode,w=x.getSnapshotBeforeUpdate(b.elementType===b.type?t:Lg(b.type,t),J);x.__reactInternalSnapshotBeforeUpdate=w}break;case 3:var u=b.stateNode.containerInfo;1===u.nodeType?u.textContent=\"\":9===u.nodeType&&u.documentElement&&u.removeChild(u.documentElement);break;case 5:case 6:case 4:case 17:break;default:throw Error(p(163));}}catch(F){W(b,b.return,F)}a=b.sibling;if(null!==a){a.return=b.return;V=a;break}V=b.return}n=Oj;Oj=!1;return n}\nfunction Qj(a,b,c){var d=b.updateQueue;d=null!==d?d.lastEffect:null;if(null!==d){var e=d=d.next;do{if((e.tag&a)===a){var f=e.destroy;e.destroy=void 0;void 0!==f&&Nj(b,c,f)}e=e.next}while(e!==d)}}function Rj(a,b){b=b.updateQueue;b=null!==b?b.lastEffect:null;if(null!==b){var c=b=b.next;do{if((c.tag&a)===a){var d=c.create;c.destroy=d()}c=c.next}while(c!==b)}}function Sj(a){var b=a.ref;if(null!==b){var c=a.stateNode;switch(a.tag){case 5:a=c;break;default:a=c}\"function\"===typeof b?b(a):b.current=a}}\nfunction Tj(a){var b=a.alternate;null!==b&&(a.alternate=null,Tj(b));a.child=null;a.deletions=null;a.sibling=null;5===a.tag&&(b=a.stateNode,null!==b&&(delete b[Of],delete b[Pf],delete b[of],delete b[Qf],delete b[Rf]));a.stateNode=null;a.return=null;a.dependencies=null;a.memoizedProps=null;a.memoizedState=null;a.pendingProps=null;a.stateNode=null;a.updateQueue=null}function Uj(a){return 5===a.tag||3===a.tag||4===a.tag}\nfunction Vj(a){a:for(;;){for(;null===a.sibling;){if(null===a.return||Uj(a.return))return null;a=a.return}a.sibling.return=a.return;for(a=a.sibling;5!==a.tag&&6!==a.tag&&18!==a.tag;){if(a.flags&2)continue a;if(null===a.child||4===a.tag)continue a;else a.child.return=a,a=a.child}if(!(a.flags&2))return a.stateNode}}\nfunction Wj(a,b,c){var d=a.tag;if(5===d||6===d)a=a.stateNode,b?8===c.nodeType?c.parentNode.insertBefore(a,b):c.insertBefore(a,b):(8===c.nodeType?(b=c.parentNode,b.insertBefore(a,c)):(b=c,b.appendChild(a)),c=c._reactRootContainer,null!==c&&void 0!==c||null!==b.onclick||(b.onclick=Bf));else if(4!==d&&(a=a.child,null!==a))for(Wj(a,b,c),a=a.sibling;null!==a;)Wj(a,b,c),a=a.sibling}\nfunction Xj(a,b,c){var d=a.tag;if(5===d||6===d)a=a.stateNode,b?c.insertBefore(a,b):c.appendChild(a);else if(4!==d&&(a=a.child,null!==a))for(Xj(a,b,c),a=a.sibling;null!==a;)Xj(a,b,c),a=a.sibling}var X=null,Yj=!1;function Zj(a,b,c){for(c=c.child;null!==c;)ak(a,b,c),c=c.sibling}\nfunction ak(a,b,c){if(lc&&\"function\"===typeof lc.onCommitFiberUnmount)try{lc.onCommitFiberUnmount(kc,c)}catch(h){}switch(c.tag){case 5:U||Mj(c,b);case 6:var d=X,e=Yj;X=null;Zj(a,b,c);X=d;Yj=e;null!==X&&(Yj?(a=X,c=c.stateNode,8===a.nodeType?a.parentNode.removeChild(c):a.removeChild(c)):X.removeChild(c.stateNode));break;case 18:null!==X&&(Yj?(a=X,c=c.stateNode,8===a.nodeType?Kf(a.parentNode,c):1===a.nodeType&&Kf(a,c),bd(a)):Kf(X,c.stateNode));break;case 4:d=X;e=Yj;X=c.stateNode.containerInfo;Yj=!0;\nZj(a,b,c);X=d;Yj=e;break;case 0:case 11:case 14:case 15:if(!U&&(d=c.updateQueue,null!==d&&(d=d.lastEffect,null!==d))){e=d=d.next;do{var f=e,g=f.destroy;f=f.tag;void 0!==g&&(0!==(f&2)?Nj(c,b,g):0!==(f&4)&&Nj(c,b,g));e=e.next}while(e!==d)}Zj(a,b,c);break;case 1:if(!U&&(Mj(c,b),d=c.stateNode,\"function\"===typeof d.componentWillUnmount))try{d.props=c.memoizedProps,d.state=c.memoizedState,d.componentWillUnmount()}catch(h){W(c,b,h)}Zj(a,b,c);break;case 21:Zj(a,b,c);break;case 22:c.mode&1?(U=(d=U)||null!==\nc.memoizedState,Zj(a,b,c),U=d):Zj(a,b,c);break;default:Zj(a,b,c)}}function bk(a){var b=a.updateQueue;if(null!==b){a.updateQueue=null;var c=a.stateNode;null===c&&(c=a.stateNode=new Lj);b.forEach(function(b){var d=ck.bind(null,a,b);c.has(b)||(c.add(b),b.then(d,d))})}}\nfunction dk(a,b){var c=b.deletions;if(null!==c)for(var d=0;de&&(e=g);d&=~f}d=e;d=B()-d;d=(120>d?120:480>d?480:1080>d?1080:1920>d?1920:3E3>d?3E3:4320>d?4320:1960*mk(d/1960))-d;if(10a?16:a;if(null===xk)var d=!1;else{a=xk;xk=null;yk=0;if(0!==(K&6))throw Error(p(331));var e=K;K|=4;for(V=a.current;null!==V;){var f=V,g=f.child;if(0!==(V.flags&16)){var h=f.deletions;if(null!==h){for(var k=0;kB()-gk?Lk(a,0):sk|=c);Ek(a,b)}function Zk(a,b){0===b&&(0===(a.mode&1)?b=1:(b=sc,sc<<=1,0===(sc&130023424)&&(sc=4194304)));var c=L();a=Zg(a,b);null!==a&&(Ac(a,b,c),Ek(a,c))}function vj(a){var b=a.memoizedState,c=0;null!==b&&(c=b.retryLane);Zk(a,c)}\nfunction ck(a,b){var c=0;switch(a.tag){case 13:var d=a.stateNode;var e=a.memoizedState;null!==e&&(c=e.retryLane);break;case 19:d=a.stateNode;break;default:throw Error(p(314));}null!==d&&d.delete(b);Zk(a,c)}var Wk;\nWk=function(a,b,c){if(null!==a)if(a.memoizedProps!==b.pendingProps||Wf.current)Ug=!0;else{if(0===(a.lanes&c)&&0===(b.flags&128))return Ug=!1,zj(a,b,c);Ug=0!==(a.flags&131072)?!0:!1}else Ug=!1,I&&0!==(b.flags&1048576)&&ug(b,ng,b.index);b.lanes=0;switch(b.tag){case 2:var d=b.type;jj(a,b);a=b.pendingProps;var e=Yf(b,H.current);Tg(b,c);e=Xh(null,b,d,a,e,c);var f=bi();b.flags|=1;\"object\"===typeof e&&null!==e&&\"function\"===typeof e.render&&void 0===e.$$typeof?(b.tag=1,b.memoizedState=null,b.updateQueue=\nnull,Zf(d)?(f=!0,cg(b)):f=!1,b.memoizedState=null!==e.state&&void 0!==e.state?e.state:null,ah(b),e.updater=nh,b.stateNode=e,e._reactInternals=b,rh(b,d,a,c),b=kj(null,b,d,!0,f,c)):(b.tag=0,I&&f&&vg(b),Yi(null,b,e,c),b=b.child);return b;case 16:d=b.elementType;a:{jj(a,b);a=b.pendingProps;e=d._init;d=e(d._payload);b.type=d;e=b.tag=$k(d);a=Lg(d,a);switch(e){case 0:b=dj(null,b,d,a,c);break a;case 1:b=ij(null,b,d,a,c);break a;case 11:b=Zi(null,b,d,a,c);break a;case 14:b=aj(null,b,d,Lg(d.type,a),c);break a}throw Error(p(306,\nd,\"\"));}return b;case 0:return d=b.type,e=b.pendingProps,e=b.elementType===d?e:Lg(d,e),dj(a,b,d,e,c);case 1:return d=b.type,e=b.pendingProps,e=b.elementType===d?e:Lg(d,e),ij(a,b,d,e,c);case 3:a:{lj(b);if(null===a)throw Error(p(387));d=b.pendingProps;f=b.memoizedState;e=f.element;bh(a,b);gh(b,d,null,c);var g=b.memoizedState;d=g.element;if(f.isDehydrated)if(f={element:d,isDehydrated:!1,cache:g.cache,pendingSuspenseBoundaries:g.pendingSuspenseBoundaries,transitions:g.transitions},b.updateQueue.baseState=\nf,b.memoizedState=f,b.flags&256){e=Ki(Error(p(423)),b);b=mj(a,b,d,c,e);break a}else if(d!==e){e=Ki(Error(p(424)),b);b=mj(a,b,d,c,e);break a}else for(yg=Lf(b.stateNode.containerInfo.firstChild),xg=b,I=!0,zg=null,c=Ch(b,null,d,c),b.child=c;c;)c.flags=c.flags&-3|4096,c=c.sibling;else{Ig();if(d===e){b=$i(a,b,c);break a}Yi(a,b,d,c)}b=b.child}return b;case 5:return Kh(b),null===a&&Eg(b),d=b.type,e=b.pendingProps,f=null!==a?a.memoizedProps:null,g=e.children,Ef(d,e)?g=null:null!==f&&Ef(d,f)&&(b.flags|=32),\nhj(a,b),Yi(a,b,g,c),b.child;case 6:return null===a&&Eg(b),null;case 13:return pj(a,b,c);case 4:return Ih(b,b.stateNode.containerInfo),d=b.pendingProps,null===a?b.child=Bh(b,null,d,c):Yi(a,b,d,c),b.child;case 11:return d=b.type,e=b.pendingProps,e=b.elementType===d?e:Lg(d,e),Zi(a,b,d,e,c);case 7:return Yi(a,b,b.pendingProps,c),b.child;case 8:return Yi(a,b,b.pendingProps.children,c),b.child;case 12:return Yi(a,b,b.pendingProps.children,c),b.child;case 10:a:{d=b.type._context;e=b.pendingProps;f=b.memoizedProps;\ng=e.value;G(Mg,d._currentValue);d._currentValue=g;if(null!==f)if(He(f.value,g)){if(f.children===e.children&&!Wf.current){b=$i(a,b,c);break a}}else for(f=b.child,null!==f&&(f.return=b);null!==f;){var h=f.dependencies;if(null!==h){g=f.child;for(var k=h.firstContext;null!==k;){if(k.context===d){if(1===f.tag){k=ch(-1,c&-c);k.tag=2;var l=f.updateQueue;if(null!==l){l=l.shared;var m=l.pending;null===m?k.next=k:(k.next=m.next,m.next=k);l.pending=k}}f.lanes|=c;k=f.alternate;null!==k&&(k.lanes|=c);Sg(f.return,\nc,b);h.lanes|=c;break}k=k.next}}else if(10===f.tag)g=f.type===b.type?null:f.child;else if(18===f.tag){g=f.return;if(null===g)throw Error(p(341));g.lanes|=c;h=g.alternate;null!==h&&(h.lanes|=c);Sg(g,c,b);g=f.sibling}else g=f.child;if(null!==g)g.return=f;else for(g=f;null!==g;){if(g===b){g=null;break}f=g.sibling;if(null!==f){f.return=g.return;g=f;break}g=g.return}f=g}Yi(a,b,e.children,c);b=b.child}return b;case 9:return e=b.type,d=b.pendingProps.children,Tg(b,c),e=Vg(e),d=d(e),b.flags|=1,Yi(a,b,d,c),\nb.child;case 14:return d=b.type,e=Lg(d,b.pendingProps),e=Lg(d.type,e),aj(a,b,d,e,c);case 15:return cj(a,b,b.type,b.pendingProps,c);case 17:return d=b.type,e=b.pendingProps,e=b.elementType===d?e:Lg(d,e),jj(a,b),b.tag=1,Zf(d)?(a=!0,cg(b)):a=!1,Tg(b,c),ph(b,d,e),rh(b,d,e,c),kj(null,b,d,!0,a,c);case 19:return yj(a,b,c);case 22:return ej(a,b,c)}throw Error(p(156,b.tag));};function Gk(a,b){return ac(a,b)}\nfunction al(a,b,c,d){this.tag=a;this.key=c;this.sibling=this.child=this.return=this.stateNode=this.type=this.elementType=null;this.index=0;this.ref=null;this.pendingProps=b;this.dependencies=this.memoizedState=this.updateQueue=this.memoizedProps=null;this.mode=d;this.subtreeFlags=this.flags=0;this.deletions=null;this.childLanes=this.lanes=0;this.alternate=null}function Bg(a,b,c,d){return new al(a,b,c,d)}function bj(a){a=a.prototype;return!(!a||!a.isReactComponent)}\nfunction $k(a){if(\"function\"===typeof a)return bj(a)?1:0;if(void 0!==a&&null!==a){a=a.$$typeof;if(a===Da)return 11;if(a===Ga)return 14}return 2}\nfunction wh(a,b){var c=a.alternate;null===c?(c=Bg(a.tag,b,a.key,a.mode),c.elementType=a.elementType,c.type=a.type,c.stateNode=a.stateNode,c.alternate=a,a.alternate=c):(c.pendingProps=b,c.type=a.type,c.flags=0,c.subtreeFlags=0,c.deletions=null);c.flags=a.flags&14680064;c.childLanes=a.childLanes;c.lanes=a.lanes;c.child=a.child;c.memoizedProps=a.memoizedProps;c.memoizedState=a.memoizedState;c.updateQueue=a.updateQueue;b=a.dependencies;c.dependencies=null===b?null:{lanes:b.lanes,firstContext:b.firstContext};\nc.sibling=a.sibling;c.index=a.index;c.ref=a.ref;return c}\nfunction yh(a,b,c,d,e,f){var g=2;d=a;if(\"function\"===typeof a)bj(a)&&(g=1);else if(\"string\"===typeof a)g=5;else a:switch(a){case ya:return Ah(c.children,e,f,b);case za:g=8;e|=8;break;case Aa:return a=Bg(12,c,b,e|2),a.elementType=Aa,a.lanes=f,a;case Ea:return a=Bg(13,c,b,e),a.elementType=Ea,a.lanes=f,a;case Fa:return a=Bg(19,c,b,e),a.elementType=Fa,a.lanes=f,a;case Ia:return qj(c,e,f,b);default:if(\"object\"===typeof a&&null!==a)switch(a.$$typeof){case Ba:g=10;break a;case Ca:g=9;break a;case Da:g=11;\nbreak a;case Ga:g=14;break a;case Ha:g=16;d=null;break a}throw Error(p(130,null==a?a:typeof a,\"\"));}b=Bg(g,c,b,e);b.elementType=a;b.type=d;b.lanes=f;return b}function Ah(a,b,c,d){a=Bg(7,a,d,b);a.lanes=c;return a}function qj(a,b,c,d){a=Bg(22,a,d,b);a.elementType=Ia;a.lanes=c;a.stateNode={isHidden:!1};return a}function xh(a,b,c){a=Bg(6,a,null,b);a.lanes=c;return a}\nfunction zh(a,b,c){b=Bg(4,null!==a.children?a.children:[],a.key,b);b.lanes=c;b.stateNode={containerInfo:a.containerInfo,pendingChildren:null,implementation:a.implementation};return b}\nfunction bl(a,b,c,d,e){this.tag=b;this.containerInfo=a;this.finishedWork=this.pingCache=this.current=this.pendingChildren=null;this.timeoutHandle=-1;this.callbackNode=this.pendingContext=this.context=null;this.callbackPriority=0;this.eventTimes=zc(0);this.expirationTimes=zc(-1);this.entangledLanes=this.finishedLanes=this.mutableReadLanes=this.expiredLanes=this.pingedLanes=this.suspendedLanes=this.pendingLanes=0;this.entanglements=zc(0);this.identifierPrefix=d;this.onRecoverableError=e;this.mutableSourceEagerHydrationData=\nnull}function cl(a,b,c,d,e,f,g,h,k){a=new bl(a,b,c,h,k);1===b?(b=1,!0===f&&(b|=8)):b=0;f=Bg(3,null,null,b);a.current=f;f.stateNode=a;f.memoizedState={element:d,isDehydrated:c,cache:null,transitions:null,pendingSuspenseBoundaries:null};ah(f);return a}function dl(a,b,c){var d=3 extends Path {\n /**\n * A value of arbitrary data associated with this location.\n */\n state: State;\n\n /**\n * A unique string associated with this location. May be used to safely store\n * and retrieve data in some other storage API, like `localStorage`.\n *\n * Note: This value is always \"default\" on the initial location.\n */\n key: string;\n}\n\n/**\n * A change to the current location.\n */\nexport interface Update {\n /**\n * The action that triggered the change.\n */\n action: Action;\n\n /**\n * The new location.\n */\n location: Location;\n\n /**\n * The delta between this location and the former location in the history stack\n */\n delta: number | null;\n}\n\n/**\n * A function that receives notifications about location changes.\n */\nexport interface Listener {\n (update: Update): void;\n}\n\n/**\n * Describes a location that is the destination of some navigation, either via\n * `history.push` or `history.replace`. This may be either a URL or the pieces\n * of a URL path.\n */\nexport type To = string | Partial;\n\n/**\n * A history is an interface to the navigation stack. The history serves as the\n * source of truth for the current location, as well as provides a set of\n * methods that may be used to change it.\n *\n * It is similar to the DOM's `window.history` object, but with a smaller, more\n * focused API.\n */\nexport interface History {\n /**\n * The last action that modified the current location. This will always be\n * Action.Pop when a history instance is first created. This value is mutable.\n */\n readonly action: Action;\n\n /**\n * The current location. This value is mutable.\n */\n readonly location: Location;\n\n /**\n * Returns a valid href for the given `to` value that may be used as\n * the value of an attribute.\n *\n * @param to - The destination URL\n */\n createHref(to: To): string;\n\n /**\n * Returns a URL for the given `to` value\n *\n * @param to - The destination URL\n */\n createURL(to: To): URL;\n\n /**\n * Encode a location the same way window.history would do (no-op for memory\n * history) so we ensure our PUSH/REPLACE navigations for data routers\n * behave the same as POP\n *\n * @param to Unencoded path\n */\n encodeLocation(to: To): Path;\n\n /**\n * Pushes a new location onto the history stack, increasing its length by one.\n * If there were any entries in the stack after the current one, they are\n * lost.\n *\n * @param to - The new URL\n * @param state - Data to associate with the new location\n */\n push(to: To, state?: any): void;\n\n /**\n * Replaces the current location in the history stack with a new one. The\n * location that was replaced will no longer be available.\n *\n * @param to - The new URL\n * @param state - Data to associate with the new location\n */\n replace(to: To, state?: any): void;\n\n /**\n * Navigates `n` entries backward/forward in the history stack relative to the\n * current index. For example, a \"back\" navigation would use go(-1).\n *\n * @param delta - The delta in the stack index\n */\n go(delta: number): void;\n\n /**\n * Sets up a listener that will be called whenever the current location\n * changes.\n *\n * @param listener - A function that will be called when the location changes\n * @returns unlisten - A function that may be used to stop listening\n */\n listen(listener: Listener): () => void;\n}\n\ntype HistoryState = {\n usr: any;\n key?: string;\n idx: number;\n};\n\nconst PopStateEventType = \"popstate\";\n//#endregion\n\n////////////////////////////////////////////////////////////////////////////////\n//#region Memory History\n////////////////////////////////////////////////////////////////////////////////\n\n/**\n * A user-supplied object that describes a location. Used when providing\n * entries to `createMemoryHistory` via its `initialEntries` option.\n */\nexport type InitialEntry = string | Partial;\n\nexport type MemoryHistoryOptions = {\n initialEntries?: InitialEntry[];\n initialIndex?: number;\n v5Compat?: boolean;\n};\n\n/**\n * A memory history stores locations in memory. This is useful in stateful\n * environments where there is no web browser, such as node tests or React\n * Native.\n */\nexport interface MemoryHistory extends History {\n /**\n * The current index in the history stack.\n */\n readonly index: number;\n}\n\n/**\n * Memory history stores the current location in memory. It is designed for use\n * in stateful non-browser environments like tests and React Native.\n */\nexport function createMemoryHistory(\n options: MemoryHistoryOptions = {}\n): MemoryHistory {\n let { initialEntries = [\"/\"], initialIndex, v5Compat = false } = options;\n let entries: Location[]; // Declare so we can access from createMemoryLocation\n entries = initialEntries.map((entry, index) =>\n createMemoryLocation(\n entry,\n typeof entry === \"string\" ? null : entry.state,\n index === 0 ? \"default\" : undefined\n )\n );\n let index = clampIndex(\n initialIndex == null ? entries.length - 1 : initialIndex\n );\n let action = Action.Pop;\n let listener: Listener | null = null;\n\n function clampIndex(n: number): number {\n return Math.min(Math.max(n, 0), entries.length - 1);\n }\n function getCurrentLocation(): Location {\n return entries[index];\n }\n function createMemoryLocation(\n to: To,\n state: any = null,\n key?: string\n ): Location {\n let location = createLocation(\n entries ? getCurrentLocation().pathname : \"/\",\n to,\n state,\n key\n );\n warning(\n location.pathname.charAt(0) === \"/\",\n `relative pathnames are not supported in memory history: ${JSON.stringify(\n to\n )}`\n );\n return location;\n }\n\n function createHref(to: To) {\n return typeof to === \"string\" ? to : createPath(to);\n }\n\n let history: MemoryHistory = {\n get index() {\n return index;\n },\n get action() {\n return action;\n },\n get location() {\n return getCurrentLocation();\n },\n createHref,\n createURL(to) {\n return new URL(createHref(to), \"http://localhost\");\n },\n encodeLocation(to: To) {\n let path = typeof to === \"string\" ? parsePath(to) : to;\n return {\n pathname: path.pathname || \"\",\n search: path.search || \"\",\n hash: path.hash || \"\",\n };\n },\n push(to, state) {\n action = Action.Push;\n let nextLocation = createMemoryLocation(to, state);\n index += 1;\n entries.splice(index, entries.length, nextLocation);\n if (v5Compat && listener) {\n listener({ action, location: nextLocation, delta: 1 });\n }\n },\n replace(to, state) {\n action = Action.Replace;\n let nextLocation = createMemoryLocation(to, state);\n entries[index] = nextLocation;\n if (v5Compat && listener) {\n listener({ action, location: nextLocation, delta: 0 });\n }\n },\n go(delta) {\n action = Action.Pop;\n let nextIndex = clampIndex(index + delta);\n let nextLocation = entries[nextIndex];\n index = nextIndex;\n if (listener) {\n listener({ action, location: nextLocation, delta });\n }\n },\n listen(fn: Listener) {\n listener = fn;\n return () => {\n listener = null;\n };\n },\n };\n\n return history;\n}\n//#endregion\n\n////////////////////////////////////////////////////////////////////////////////\n//#region Browser History\n////////////////////////////////////////////////////////////////////////////////\n\n/**\n * A browser history stores the current location in regular URLs in a web\n * browser environment. This is the standard for most web apps and provides the\n * cleanest URLs the browser's address bar.\n *\n * @see https://github.com/remix-run/history/tree/main/docs/api-reference.md#browserhistory\n */\nexport interface BrowserHistory extends UrlHistory {}\n\nexport type BrowserHistoryOptions = UrlHistoryOptions;\n\n/**\n * Browser history stores the location in regular URLs. This is the standard for\n * most web apps, but it requires some configuration on the server to ensure you\n * serve the same app at multiple URLs.\n *\n * @see https://github.com/remix-run/history/tree/main/docs/api-reference.md#createbrowserhistory\n */\nexport function createBrowserHistory(\n options: BrowserHistoryOptions = {}\n): BrowserHistory {\n function createBrowserLocation(\n window: Window,\n globalHistory: Window[\"history\"]\n ) {\n let { pathname, search, hash } = window.location;\n return createLocation(\n \"\",\n { pathname, search, hash },\n // state defaults to `null` because `window.history.state` does\n (globalHistory.state && globalHistory.state.usr) || null,\n (globalHistory.state && globalHistory.state.key) || \"default\"\n );\n }\n\n function createBrowserHref(window: Window, to: To) {\n return typeof to === \"string\" ? to : createPath(to);\n }\n\n return getUrlBasedHistory(\n createBrowserLocation,\n createBrowserHref,\n null,\n options\n );\n}\n//#endregion\n\n////////////////////////////////////////////////////////////////////////////////\n//#region Hash History\n////////////////////////////////////////////////////////////////////////////////\n\n/**\n * A hash history stores the current location in the fragment identifier portion\n * of the URL in a web browser environment.\n *\n * This is ideal for apps that do not control the server for some reason\n * (because the fragment identifier is never sent to the server), including some\n * shared hosting environments that do not provide fine-grained controls over\n * which pages are served at which URLs.\n *\n * @see https://github.com/remix-run/history/tree/main/docs/api-reference.md#hashhistory\n */\nexport interface HashHistory extends UrlHistory {}\n\nexport type HashHistoryOptions = UrlHistoryOptions;\n\n/**\n * Hash history stores the location in window.location.hash. This makes it ideal\n * for situations where you don't want to send the location to the server for\n * some reason, either because you do cannot configure it or the URL space is\n * reserved for something else.\n *\n * @see https://github.com/remix-run/history/tree/main/docs/api-reference.md#createhashhistory\n */\nexport function createHashHistory(\n options: HashHistoryOptions = {}\n): HashHistory {\n function createHashLocation(\n window: Window,\n globalHistory: Window[\"history\"]\n ) {\n let {\n pathname = \"/\",\n search = \"\",\n hash = \"\",\n } = parsePath(window.location.hash.substr(1));\n\n // Hash URL should always have a leading / just like window.location.pathname\n // does, so if an app ends up at a route like /#something then we add a\n // leading slash so all of our path-matching behaves the same as if it would\n // in a browser router. This is particularly important when there exists a\n // root splat route () since that matches internally against\n // \"/*\" and we'd expect /#something to 404 in a hash router app.\n if (!pathname.startsWith(\"/\") && !pathname.startsWith(\".\")) {\n pathname = \"/\" + pathname;\n }\n\n return createLocation(\n \"\",\n { pathname, search, hash },\n // state defaults to `null` because `window.history.state` does\n (globalHistory.state && globalHistory.state.usr) || null,\n (globalHistory.state && globalHistory.state.key) || \"default\"\n );\n }\n\n function createHashHref(window: Window, to: To) {\n let base = window.document.querySelector(\"base\");\n let href = \"\";\n\n if (base && base.getAttribute(\"href\")) {\n let url = window.location.href;\n let hashIndex = url.indexOf(\"#\");\n href = hashIndex === -1 ? url : url.slice(0, hashIndex);\n }\n\n return href + \"#\" + (typeof to === \"string\" ? to : createPath(to));\n }\n\n function validateHashLocation(location: Location, to: To) {\n warning(\n location.pathname.charAt(0) === \"/\",\n `relative pathnames are not supported in hash history.push(${JSON.stringify(\n to\n )})`\n );\n }\n\n return getUrlBasedHistory(\n createHashLocation,\n createHashHref,\n validateHashLocation,\n options\n );\n}\n//#endregion\n\n////////////////////////////////////////////////////////////////////////////////\n//#region UTILS\n////////////////////////////////////////////////////////////////////////////////\n\n/**\n * @private\n */\nexport function invariant(value: boolean, message?: string): asserts value;\nexport function invariant(\n value: T | null | undefined,\n message?: string\n): asserts value is T;\nexport function invariant(value: any, message?: string) {\n if (value === false || value === null || typeof value === \"undefined\") {\n throw new Error(message);\n }\n}\n\nexport function warning(cond: any, message: string) {\n if (!cond) {\n // eslint-disable-next-line no-console\n if (typeof console !== \"undefined\") console.warn(message);\n\n try {\n // Welcome to debugging history!\n //\n // This error is thrown as a convenience, so you can more easily\n // find the source for a warning that appears in the console by\n // enabling \"pause on exceptions\" in your JavaScript debugger.\n throw new Error(message);\n // eslint-disable-next-line no-empty\n } catch (e) {}\n }\n}\n\nfunction createKey() {\n return Math.random().toString(36).substr(2, 8);\n}\n\n/**\n * For browser-based histories, we combine the state and key into an object\n */\nfunction getHistoryState(location: Location, index: number): HistoryState {\n return {\n usr: location.state,\n key: location.key,\n idx: index,\n };\n}\n\n/**\n * Creates a Location object with a unique key from the given Path\n */\nexport function createLocation(\n current: string | Location,\n to: To,\n state: any = null,\n key?: string\n): Readonly {\n let location: Readonly = {\n pathname: typeof current === \"string\" ? current : current.pathname,\n search: \"\",\n hash: \"\",\n ...(typeof to === \"string\" ? parsePath(to) : to),\n state,\n // TODO: This could be cleaned up. push/replace should probably just take\n // full Locations now and avoid the need to run through this flow at all\n // But that's a pretty big refactor to the current test suite so going to\n // keep as is for the time being and just let any incoming keys take precedence\n key: (to && (to as Location).key) || key || createKey(),\n };\n return location;\n}\n\n/**\n * Creates a string URL path from the given pathname, search, and hash components.\n */\nexport function createPath({\n pathname = \"/\",\n search = \"\",\n hash = \"\",\n}: Partial) {\n if (search && search !== \"?\")\n pathname += search.charAt(0) === \"?\" ? search : \"?\" + search;\n if (hash && hash !== \"#\")\n pathname += hash.charAt(0) === \"#\" ? hash : \"#\" + hash;\n return pathname;\n}\n\n/**\n * Parses a string URL path into its separate pathname, search, and hash components.\n */\nexport function parsePath(path: string): Partial {\n let parsedPath: Partial = {};\n\n if (path) {\n let hashIndex = path.indexOf(\"#\");\n if (hashIndex >= 0) {\n parsedPath.hash = path.substr(hashIndex);\n path = path.substr(0, hashIndex);\n }\n\n let searchIndex = path.indexOf(\"?\");\n if (searchIndex >= 0) {\n parsedPath.search = path.substr(searchIndex);\n path = path.substr(0, searchIndex);\n }\n\n if (path) {\n parsedPath.pathname = path;\n }\n }\n\n return parsedPath;\n}\n\nexport interface UrlHistory extends History {}\n\nexport type UrlHistoryOptions = {\n window?: Window;\n v5Compat?: boolean;\n};\n\nfunction getUrlBasedHistory(\n getLocation: (window: Window, globalHistory: Window[\"history\"]) => Location,\n createHref: (window: Window, to: To) => string,\n validateLocation: ((location: Location, to: To) => void) | null,\n options: UrlHistoryOptions = {}\n): UrlHistory {\n let { window = document.defaultView!, v5Compat = false } = options;\n let globalHistory = window.history;\n let action = Action.Pop;\n let listener: Listener | null = null;\n\n let index = getIndex()!;\n // Index should only be null when we initialize. If not, it's because the\n // user called history.pushState or history.replaceState directly, in which\n // case we should log a warning as it will result in bugs.\n if (index == null) {\n index = 0;\n globalHistory.replaceState({ ...globalHistory.state, idx: index }, \"\");\n }\n\n function getIndex(): number {\n let state = globalHistory.state || { idx: null };\n return state.idx;\n }\n\n function handlePop() {\n action = Action.Pop;\n let nextIndex = getIndex();\n let delta = nextIndex == null ? null : nextIndex - index;\n index = nextIndex;\n if (listener) {\n listener({ action, location: history.location, delta });\n }\n }\n\n function push(to: To, state?: any) {\n action = Action.Push;\n let location = createLocation(history.location, to, state);\n if (validateLocation) validateLocation(location, to);\n\n index = getIndex() + 1;\n let historyState = getHistoryState(location, index);\n let url = history.createHref(location);\n\n // try...catch because iOS limits us to 100 pushState calls :/\n try {\n globalHistory.pushState(historyState, \"\", url);\n } catch (error) {\n // If the exception is because `state` can't be serialized, let that throw\n // outwards just like a replace call would so the dev knows the cause\n // https://html.spec.whatwg.org/multipage/nav-history-apis.html#shared-history-push/replace-state-steps\n // https://html.spec.whatwg.org/multipage/structured-data.html#structuredserializeinternal\n if (error instanceof DOMException && error.name === \"DataCloneError\") {\n throw error;\n }\n // They are going to lose state here, but there is no real\n // way to warn them about it since the page will refresh...\n window.location.assign(url);\n }\n\n if (v5Compat && listener) {\n listener({ action, location: history.location, delta: 1 });\n }\n }\n\n function replace(to: To, state?: any) {\n action = Action.Replace;\n let location = createLocation(history.location, to, state);\n if (validateLocation) validateLocation(location, to);\n\n index = getIndex();\n let historyState = getHistoryState(location, index);\n let url = history.createHref(location);\n globalHistory.replaceState(historyState, \"\", url);\n\n if (v5Compat && listener) {\n listener({ action, location: history.location, delta: 0 });\n }\n }\n\n function createURL(to: To): URL {\n // window.location.origin is \"null\" (the literal string value) in Firefox\n // under certain conditions, notably when serving from a local HTML file\n // See https://bugzilla.mozilla.org/show_bug.cgi?id=878297\n let base =\n window.location.origin !== \"null\"\n ? window.location.origin\n : window.location.href;\n\n let href = typeof to === \"string\" ? to : createPath(to);\n invariant(\n base,\n `No window.location.(origin|href) available to create URL for href: ${href}`\n );\n return new URL(href, base);\n }\n\n let history: History = {\n get action() {\n return action;\n },\n get location() {\n return getLocation(window, globalHistory);\n },\n listen(fn: Listener) {\n if (listener) {\n throw new Error(\"A history only accepts one active listener\");\n }\n window.addEventListener(PopStateEventType, handlePop);\n listener = fn;\n\n return () => {\n window.removeEventListener(PopStateEventType, handlePop);\n listener = null;\n };\n },\n createHref(to) {\n return createHref(window, to);\n },\n createURL,\n encodeLocation(to) {\n // Encode a Location the same way window.location would\n let url = createURL(to);\n return {\n pathname: url.pathname,\n search: url.search,\n hash: url.hash,\n };\n },\n push,\n replace,\n go(n) {\n return globalHistory.go(n);\n },\n };\n\n return history;\n}\n\n//#endregion\n","import unsupportedIterableToArray from \"./unsupportedIterableToArray.js\";\nfunction _createForOfIteratorHelper(r, e) {\n var t = \"undefined\" != typeof Symbol && r[Symbol.iterator] || r[\"@@iterator\"];\n if (!t) {\n if (Array.isArray(r) || (t = unsupportedIterableToArray(r)) || e && r && \"number\" == typeof r.length) {\n t && (r = t);\n var _n = 0,\n F = function F() {};\n return {\n s: F,\n n: function n() {\n return _n >= r.length ? {\n done: !0\n } : {\n done: !1,\n value: r[_n++]\n };\n },\n e: function e(r) {\n throw r;\n },\n f: F\n };\n }\n throw new TypeError(\"Invalid attempt to iterate non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\");\n }\n var o,\n a = !0,\n u = !1;\n return {\n s: function s() {\n t = t.call(r);\n },\n n: function n() {\n var r = t.next();\n return a = r.done, r;\n },\n e: function e(r) {\n u = !0, o = r;\n },\n f: function f() {\n try {\n a || null == t[\"return\"] || t[\"return\"]();\n } finally {\n if (u) throw o;\n }\n }\n };\n}\nexport { _createForOfIteratorHelper as default };","import type { Location, Path, To } from \"./history\";\nimport { invariant, parsePath, warning } from \"./history\";\n\n/**\n * Map of routeId -> data returned from a loader/action/error\n */\nexport interface RouteData {\n [routeId: string]: any;\n}\n\nexport enum ResultType {\n data = \"data\",\n deferred = \"deferred\",\n redirect = \"redirect\",\n error = \"error\",\n}\n\n/**\n * Successful result from a loader or action\n */\nexport interface SuccessResult {\n type: ResultType.data;\n data: any;\n statusCode?: number;\n headers?: Headers;\n}\n\n/**\n * Successful defer() result from a loader or action\n */\nexport interface DeferredResult {\n type: ResultType.deferred;\n deferredData: DeferredData;\n statusCode?: number;\n headers?: Headers;\n}\n\n/**\n * Redirect result from a loader or action\n */\nexport interface RedirectResult {\n type: ResultType.redirect;\n status: number;\n location: string;\n revalidate: boolean;\n reloadDocument?: boolean;\n}\n\n/**\n * Unsuccessful result from a loader or action\n */\nexport interface ErrorResult {\n type: ResultType.error;\n error: any;\n headers?: Headers;\n}\n\n/**\n * Result from a loader or action - potentially successful or unsuccessful\n */\nexport type DataResult =\n | SuccessResult\n | DeferredResult\n | RedirectResult\n | ErrorResult;\n\ntype LowerCaseFormMethod = \"get\" | \"post\" | \"put\" | \"patch\" | \"delete\";\ntype UpperCaseFormMethod = Uppercase;\n\n/**\n * Users can specify either lowercase or uppercase form methods on