From 45ab4747fa87431682f63216ddcd4a318e9413d2 Mon Sep 17 00:00:00 2001 From: manmeetnagii Date: Thu, 12 Dec 2024 14:00:47 +0530 Subject: [PATCH 1/9] Enhancement: Update the button layout in Assets Page --- src/components/Assets/AssetsList.tsx | 226 +++++++++++++++------------ 1 file changed, 130 insertions(+), 96 deletions(-) diff --git a/src/components/Assets/AssetsList.tsx b/src/components/Assets/AssetsList.tsx index 685d7dfa460..602a2a84105 100644 --- a/src/components/Assets/AssetsList.tsx +++ b/src/components/Assets/AssetsList.tsx @@ -17,7 +17,6 @@ import Loading from "@/components/Common/Loading"; import Page from "@/components/Common/Page"; import FacilitiesSelectDialogue from "@/components/ExternalResult/FacilitiesSelectDialogue"; import { FacilityModel } from "@/components/Facility/models"; -import SearchInput from "@/components/Form/SearchInput"; import useFilters from "@/hooks/useFilters"; import { useIsAuthorized } from "@/hooks/useIsAuthorized"; @@ -29,6 +28,8 @@ import routes from "@/Utils/request/api"; import request from "@/Utils/request/request"; import useQuery from "@/Utils/request/useQuery"; +import SearchByMultipleFields from "../Common/SearchByMultipleFields"; + const AssetsList = () => { const { t } = useTranslation(); const { @@ -38,9 +39,10 @@ const AssetsList = () => { FilterBadges, advancedFilter, resultsPerPage, + clearSearch, } = useFilters({ limit: 18, - cacheBlacklist: ["search"], + cacheBlacklist: ["name", "qr_code_id", "serial_number"], }); const [assets, setAssets] = useState([{} as AssetData]); const [isLoading, setIsLoading] = useState(false); @@ -56,6 +58,9 @@ const AssetsList = () => { const params = { limit: resultsPerPage, page: qParams.page, + qr_code_id: qParams.qr_code_id || undefined, + name: qParams.name || undefined, + serial_number: qParams.serial_number || undefined, offset: (qParams.page ? qParams.page - 1 : 0) * resultsPerPage, search_text: qParams.search || "", facility: qParams.facility || "", @@ -173,6 +178,33 @@ const AssetsList = () => { AuthorizeFor(["DistrictAdmin", "StateAdmin"]), ); + const searchOptions = [ + { + key: "name", + label: "Name", + type: "text" as const, + placeholder: "Search by Name", + value: qParams.name || undefined, + shortcutKey: "n", + }, + { + key: "serial_number", + label: "Serial Number", + type: "text" as const, + placeholder: "Search by Serial Number", + value: qParams.serial_number || undefined, + shortcutKey: "p", + }, + { + key: "asset_qr_id", + label: "QR Code ID", + type: "text" as const, + placeholder: "Search by QR Code ID", + value: qParams.qr_code_id || undefined, + shortcutKey: "u", + }, + ]; + if (isScannerActive) return (
@@ -308,102 +340,11 @@ const AssetsList = () => { breadcrumbs={false} hideBack options={ - <> - {authorizedForImportExport && ( -
- - ), - onClick: () => setImportAssetModalOpen(true), - }, - }, - { - label: "Export Assets (JSON)", - action: async () => { - const { data } = await request(routes.listAssets, { - query: { ...qParams, json: true, limit: totalCount }, - }); - return data ?? null; - }, - type: "json", - filePrefix: `assets_${facility?.name ?? "all"}`, - options: { - icon: , - disabled: totalCount === 0 || !authorizedForImportExport, - id: "export-json-option", - }, - }, - { - label: "Export Assets (CSV)", - action: async () => { - const { data } = await request(routes.listAssets, { - query: { ...qParams, csv: true, limit: totalCount }, - }); - return data ?? null; - }, - type: "csv", - filePrefix: `assets_${facility?.name ?? "all"}`, - options: { - icon: , - disabled: totalCount === 0 || !authorizedForImportExport, - id: "export-csv-option", - }, - }, - ]} - /> -
- )} - - } - > -
- -
- updateQuery({ [e.name]: e.value })} - placeholder="Search by name/serial no./QR code ID" - /> -
-
-
-
- advancedFilter.setShow(true)} - /> -
- setIsScannerActive(true)} - > - Scan Asset - QR - -
-
+
+
{ if (qParams.facility) { navigate(`/facility/${qParams.facility}/assets/new`); @@ -416,7 +357,100 @@ const AssetsList = () => { {t("create_asset")}
+
+
+ advancedFilter.setShow(true)} + /> +
+ setIsScannerActive(true)} + > + Scan Asset + QR + + + {authorizedForImportExport && ( +
+ + ), + onClick: () => setImportAssetModalOpen(true), + }, + }, + { + label: "Export Assets (JSON)", + action: async () => { + const { data } = await request(routes.listAssets, { + query: { ...qParams, json: true, limit: totalCount }, + }); + return data ?? null; + }, + type: "json", + filePrefix: `assets_${facility?.name ?? "all"}`, + options: { + icon: , + disabled: + totalCount === 0 || !authorizedForImportExport, + id: "export-json-option", + }, + }, + { + label: "Export Assets (CSV)", + action: async () => { + const { data } = await request(routes.listAssets, { + query: { ...qParams, csv: true, limit: totalCount }, + }); + return data ?? null; + }, + type: "csv", + filePrefix: `assets_${facility?.name ?? "all"}`, + options: { + icon: , + disabled: + totalCount === 0 || !authorizedForImportExport, + id: "export-csv-option", + }, + }, + ]} + /> +
+ )} +
+ } + > +
+ + + updateQuery({ search: value })} + clearSearch={clearSearch} + className="w-full" + />
{isLoading ? ( From 6a3670d978122e6e7f4aaea43df9c74ce9c8a216 Mon Sep 17 00:00:00 2001 From: manmeetnagii Date: Thu, 12 Dec 2024 19:22:01 +0530 Subject: [PATCH 2/9] Refactored: Updated ButtonV2 to use ShadCN button --- src/CAREUI/interactive/FiltersSlideover.tsx | 12 ++++++----- src/components/Assets/AssetsList.tsx | 24 ++++++++++++++------- src/components/Common/Export.tsx | 18 +++++++--------- 3 files changed, 31 insertions(+), 23 deletions(-) diff --git a/src/CAREUI/interactive/FiltersSlideover.tsx b/src/CAREUI/interactive/FiltersSlideover.tsx index 959fd0621e8..c6ee12e6df3 100644 --- a/src/CAREUI/interactive/FiltersSlideover.tsx +++ b/src/CAREUI/interactive/FiltersSlideover.tsx @@ -4,6 +4,8 @@ import { useTranslation } from "react-i18next"; import CareIcon from "@/CAREUI/icons/CareIcon"; import SlideOver from "@/CAREUI/interactive/SlideOver"; +import { Button } from "@/components/ui/button"; + import ButtonV2 from "@/components/Common/ButtonV2"; import useFilters from "@/hooks/useFilters"; @@ -58,15 +60,15 @@ export default function FiltersSlideover({ export const AdvancedFilterButton = ({ onClick }: { onClick: () => void }) => { const { t } = useTranslation(); return ( - {t("advanced_filters")} - + ); }; diff --git a/src/components/Assets/AssetsList.tsx b/src/components/Assets/AssetsList.tsx index ba70379f855..5e39f3719f3 100644 --- a/src/components/Assets/AssetsList.tsx +++ b/src/components/Assets/AssetsList.tsx @@ -11,13 +11,13 @@ import { AdvancedFilterButton } from "@/CAREUI/interactive/FiltersSlideover"; import AssetFilter from "@/components/Assets/AssetFilter"; import AssetImportModal from "@/components/Assets/AssetImportModal"; import { AssetData, assetClassProps } from "@/components/Assets/AssetTypes"; -import ButtonV2 from "@/components/Common/ButtonV2"; import ExportMenu from "@/components/Common/Export"; import Loading from "@/components/Common/Loading"; import Page from "@/components/Common/Page"; import FacilitiesSelectDialogue from "@/components/ExternalResult/FacilitiesSelectDialogue"; import { FacilityModel } from "@/components/Facility/models"; +import useAuthUser from "@/hooks/useAuthUser"; import useFilters from "@/hooks/useFilters"; import { useIsAuthorized } from "@/hooks/useIsAuthorized"; @@ -29,6 +29,7 @@ import request from "@/Utils/request/request"; import useTanStackQueryInstead from "@/Utils/request/useQuery"; import SearchByMultipleFields from "../Common/SearchByMultipleFields"; +import { Button } from "../ui/button"; const AssetsList = () => { const { t } = useTranslation(); @@ -44,6 +45,7 @@ const AssetsList = () => { limit: 18, cacheBlacklist: ["name", "qr_code_id", "serial_number"], }); + const authUser = useAuthUser(); const [assets, setAssets] = useState([{} as AssetData]); const [isLoading, setIsLoading] = useState(false); const [isScannerActive, setIsScannerActive] = useState(false); @@ -119,6 +121,8 @@ const AssetsList = () => { }, ); + const isDisabled = !NonReadOnlyUsers(authUser.user_type); + function isValidURL(url: string) { try { new URL(url); @@ -351,9 +355,11 @@ const AssetsList = () => { options={
- { if (qParams.facility) { navigate(`/facility/${qParams.facility}/assets/new`); @@ -364,7 +370,7 @@ const AssetsList = () => { > {t("create_asset")} - +
@@ -372,13 +378,15 @@ const AssetsList = () => { onClick={() => advancedFilter.setShow(true)} />
- setIsScannerActive(true)} + className="gap-2" > Scan Asset QR - + {authorizedForImportExport && (
{ let action = item.action; @@ -63,13 +65,11 @@ export const ExportMenu = ({ exportFile(action, item.filePrefix, item.type, item.parse); } }} - border - ghost className="py-2.5" > {isExporting ? "Exporting..." : label} - + ); } @@ -79,7 +79,7 @@ export const ExportMenu = ({ disabled={isExporting || disabled} title={isExporting ? "Exporting..." : label} icon={} - className="tooltip border-primary-500 bg-white text-primary-500 hover:bg-primary-100 enabled:border" + className="tooltip border-primary-700 bg-white text-primary-700 hover:bg-primary-100 enabled:border" > {exportItems.map((item) => ( - { let action = props.action; @@ -132,8 +132,6 @@ export const ExportButton = ({ }} className="tooltip mx-2 p-4 text-lg text-secondary-800 disabled:bg-transparent disabled:text-secondary-500" variant="secondary" - ghost - circle > {isExporting ? ( @@ -143,7 +141,7 @@ export const ExportButton = ({ {props.tooltip || "Export"} - + ); }; From ca130ab1815c2758c7898bc27b38af1e95b069b4 Mon Sep 17 00:00:00 2001 From: manmeetnagii Date: Thu, 12 Dec 2024 19:35:58 +0530 Subject: [PATCH 3/9] fixes mobile view --- src/components/Assets/AssetsList.tsx | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/components/Assets/AssetsList.tsx b/src/components/Assets/AssetsList.tsx index 5e39f3719f3..0a1d30155f4 100644 --- a/src/components/Assets/AssetsList.tsx +++ b/src/components/Assets/AssetsList.tsx @@ -359,7 +359,7 @@ const AssetsList = () => { disabled={isDisabled} variant={"primary"} size={"lg"} - className="gap-2" + className="gap-2 w-full" onClick={() => { if (qParams.facility) { navigate(`/facility/${qParams.facility}/assets/new`); @@ -382,7 +382,7 @@ const AssetsList = () => { variant={"primary"} size={"lg"} onClick={() => setIsScannerActive(true)} - className="gap-2" + className="gap-2 w-full" > Scan Asset QR From bac9003d774b7e76f809af12a7cf858821980cf4 Mon Sep 17 00:00:00 2001 From: manmeetnagii Date: Fri, 13 Dec 2024 21:49:39 +0530 Subject: [PATCH 4/9] Checked cypress tests --- src/components/Assets/AssetsList.tsx | 105 ++++++++++++++------------- 1 file changed, 54 insertions(+), 51 deletions(-) diff --git a/src/components/Assets/AssetsList.tsx b/src/components/Assets/AssetsList.tsx index 0a1d30155f4..72611d172c7 100644 --- a/src/components/Assets/AssetsList.tsx +++ b/src/components/Assets/AssetsList.tsx @@ -43,9 +43,8 @@ const AssetsList = () => { clearSearch, } = useFilters({ limit: 18, - cacheBlacklist: ["name", "qr_code_id", "serial_number"], + cacheBlacklist: ["name", "serial_number", "qr_code_id"], }); - const authUser = useAuthUser(); const [assets, setAssets] = useState([{} as AssetData]); const [isLoading, setIsLoading] = useState(false); const [isScannerActive, setIsScannerActive] = useState(false); @@ -60,9 +59,9 @@ const AssetsList = () => { const params = { limit: resultsPerPage, page: qParams.page, - qr_code_id: qParams.qr_code_id || undefined, - name: qParams.name || undefined, - serial_number: qParams.serial_number || undefined, + name: qParams.name || "", + serial_number: qParams.serial_number || "", + qr_code_id: qParams.qr_code_id || "", offset: (qParams.page ? qParams.page - 1 : 0) * resultsPerPage, search_text: qParams.search || "", facility: qParams.facility || "", @@ -121,6 +120,7 @@ const AssetsList = () => { }, ); + const authUser = useAuthUser(); const isDisabled = !NonReadOnlyUsers(authUser.user_type); function isValidURL(url: string) { @@ -191,33 +191,6 @@ const AssetsList = () => { AuthorizeFor(["DistrictAdmin", "StateAdmin"]), ); - const searchOptions = [ - { - key: "name", - label: "Name", - type: "text" as const, - placeholder: "Search by Name", - value: qParams.name || undefined, - shortcutKey: "n", - }, - { - key: "serial_number", - label: "Serial Number", - type: "text" as const, - placeholder: "Search by Serial Number", - value: qParams.serial_number || undefined, - shortcutKey: "p", - }, - { - key: "asset_qr_id", - label: "QR Code ID", - type: "text" as const, - placeholder: "Search by QR Code ID", - value: qParams.qr_code_id || undefined, - shortcutKey: "u", - }, - ]; - if (isScannerActive) return (
@@ -347,19 +320,50 @@ const AssetsList = () => { ); } + const searchOptions = [ + { + key: "name", + label: "Name", + type: "text" as const, + placeholder: "Search by Name", + value: qParams.name || "", + shortcutKey: "n", + }, + { + key: "serial_number", + label: "Serial No.", + type: "text" as const, + placeholder: "Search by Serial No.", + value: qParams.serial_number || "", + shortcutKey: "u", + }, + { + key: "asset_qr_id", + label: "QR Code ID", + type: "text" as const, + placeholder: "Search by QR Code ID", + value: qParams.qr_code_id || "", + shortcutKey: "p", + }, + ]; + return ( -
+
-
- advancedFilter.setShow(true)} - /> -
+ advancedFilter.setShow(true)} + /> + - {authorizedForImportExport && ( -
+
+ {authorizedForImportExport && ( { icon: ( ), onClick: () => setImportAssetModalOpen(true), @@ -446,8 +449,8 @@ const AssetsList = () => { }, ]} /> -
- )} + )} +
} @@ -462,7 +465,7 @@ const AssetsList = () => { /> updateQuery({ search: value })} clearSearch={clearSearch} From 1b02dc22cbdd386a9a2cc2a90e5d3994011808d6 Mon Sep 17 00:00:00 2001 From: manmeetnagii Date: Sat, 14 Dec 2024 13:57:43 +0530 Subject: [PATCH 5/9] changed dropdown to Shadcn dropdown --- src/components/Common/Export.tsx | 78 ++++++++++++++++++++------------ 1 file changed, 48 insertions(+), 30 deletions(-) diff --git a/src/components/Common/Export.tsx b/src/components/Common/Export.tsx index e8a61dde73d..18e7328af7e 100644 --- a/src/components/Common/Export.tsx +++ b/src/components/Common/Export.tsx @@ -1,9 +1,8 @@ +import { cn } from "@/lib/utils"; + import CareIcon from "@/CAREUI/icons/CareIcon"; -import DropdownMenu, { - DropdownItem, - DropdownItemProps, -} from "@/components/Common/Menu"; +import { DropdownItemProps } from "@/components/Common/Menu"; import useExport from "@/hooks/useExport"; @@ -11,6 +10,12 @@ import request from "@/Utils/request/request"; import { Route } from "@/Utils/request/types"; import { Button } from "../ui/button"; +import { + DropdownMenu, + DropdownMenuContent, + DropdownMenuItem, + DropdownMenuTrigger, +} from "../ui/dropdown-menu"; interface ExportItem { options?: DropdownItemProps; @@ -74,33 +79,46 @@ export const ExportMenu = ({ } return ( -
- } - className="tooltip border-primary-700 bg-white text-primary-700 hover:bg-primary-100 enabled:border" - > - {exportItems.map((item) => ( - { - let action = item.action; - if (item.route) { - action = async () => { - const { data } = await request(item.route!); - return data ?? null; - }; - } - if (action) { - exportFile(action, item.filePrefix, item.type, item.parse); - } - }} - {...item.options} +
+ + + + + + {exportItems.map((item) => ( +
{ + let action = item.action; + if (item.route) { + action = async () => { + const { data } = await request(item.route!); + return data ?? null; + }; + } + if (action) { + exportFile(action, item.filePrefix, item.type, item.parse); + } + }} + {...item.options} + > + + {item.label} + +
+ ))} +
); From e011a76693325254d886ea3668cbe9ebc7cf7b0d Mon Sep 17 00:00:00 2001 From: manmeetnagii Date: Sat, 14 Dec 2024 16:02:39 +0530 Subject: [PATCH 6/9] changed dropdown to Shadcn dropdown --- src/components/Assets/AssetsList.tsx | 2 +- src/components/Common/Export.tsx | 8 +++----- 2 files changed, 4 insertions(+), 6 deletions(-) diff --git a/src/components/Assets/AssetsList.tsx b/src/components/Assets/AssetsList.tsx index 72611d172c7..edb9de0458d 100644 --- a/src/components/Assets/AssetsList.tsx +++ b/src/components/Assets/AssetsList.tsx @@ -407,7 +407,7 @@ const AssetsList = () => { icon: ( ), onClick: () => setImportAssetModalOpen(true), diff --git a/src/components/Common/Export.tsx b/src/components/Common/Export.tsx index 18e7328af7e..2fe4e342bd7 100644 --- a/src/components/Common/Export.tsx +++ b/src/components/Common/Export.tsx @@ -88,10 +88,7 @@ export const ExportMenu = ({ className="w-full gap-2 cursor-pointer" disabled={isExporting || disabled} > - + {isExporting ? "Exporting..." : label} @@ -113,7 +110,8 @@ export const ExportMenu = ({ }} {...item.options} > - + + {item.options?.icon} {item.label}
From c7a2a4d4ebb714147e54d8bdca097e0d30365bad Mon Sep 17 00:00:00 2001 From: manmeetnagii Date: Sun, 15 Dec 2024 12:58:54 +0530 Subject: [PATCH 7/9] changed dropdown to Shadcn dropdown --- src/components/Common/Export.tsx | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/src/components/Common/Export.tsx b/src/components/Common/Export.tsx index 2fe4e342bd7..c27fb2d58a0 100644 --- a/src/components/Common/Export.tsx +++ b/src/components/Common/Export.tsx @@ -92,7 +92,9 @@ export const ExportMenu = ({ {isExporting ? "Exporting..." : label} - + {exportItems.map((item) => (
Date: Sun, 15 Dec 2024 22:15:09 +0530 Subject: [PATCH 8/9] changed dropdown to Shadcn dropdown --- src/components/Common/Export.tsx | 82 +++-- ....timestamp-1734272200960-c34409c35bb48.mjs | 282 ++++++++++++++++++ 2 files changed, 333 insertions(+), 31 deletions(-) create mode 100644 vite.config.mts.timestamp-1734272200960-c34409c35bb48.mjs diff --git a/src/components/Common/Export.tsx b/src/components/Common/Export.tsx index c27fb2d58a0..42efe38fd27 100644 --- a/src/components/Common/Export.tsx +++ b/src/components/Common/Export.tsx @@ -5,9 +5,12 @@ import CareIcon from "@/CAREUI/icons/CareIcon"; import { DropdownItemProps } from "@/components/Common/Menu"; import useExport from "@/hooks/useExport"; +import { useIsAuthorized } from "@/hooks/useIsAuthorized"; +import { Anyone, AuthorizedForCB } from "@/Utils/AuthorizeFor"; import request from "@/Utils/request/request"; import { Route } from "@/Utils/request/types"; +import { classNames } from "@/Utils/utils"; import { Button } from "../ui/button"; import { @@ -28,9 +31,11 @@ interface ExportItem { } interface ExportMenuProps { + variant?: string; disabled?: boolean | undefined; label?: string; exportItems: ExportItem[]; + authorizeFor?: AuthorizedForCB | undefined; } interface ExportButtonProps { @@ -48,8 +53,10 @@ export const ExportMenu = ({ label = "Export", disabled, exportItems, + authorizeFor = Anyone, }: ExportMenuProps) => { const { isExporting, exportFile } = useExport(); + const isAuthorized = useIsAuthorized(authorizeFor); if (exportItems.length === 1) { const item = exportItems[0]; @@ -79,46 +86,59 @@ export const ExportMenu = ({ } return ( -
+
- + - - {exportItems.map((item) => ( -
{ - let action = item.action; - if (item.route) { - action = async () => { - const { data } = await request(item.route!); - return data ?? null; - }; - } - if (action) { - exportFile(action, item.filePrefix, item.type, item.parse); - } - }} - {...item.options} - > - - {item.options?.icon} - {item.label} - -
- ))} -
+ {label !== "Importing..." && ( + + {exportItems.map((item) => ( +
+ +
{ + let action = item.action; + if (item.route) { + action = async () => { + const { data } = await request(item.route!); + return data ?? null; + }; + } + if (action) { + exportFile( + action, + item.filePrefix, + item.type, + item.parse, + ); + } + }} + > + {item.options?.icon} + {item.label} +
+
+
+ ))} +
+ )}
); diff --git a/vite.config.mts.timestamp-1734272200960-c34409c35bb48.mjs b/vite.config.mts.timestamp-1734272200960-c34409c35bb48.mjs new file mode 100644 index 00000000000..7ab7e31514f --- /dev/null +++ b/vite.config.mts.timestamp-1734272200960-c34409c35bb48.mjs @@ -0,0 +1,282 @@ +// vite.config.mts +import { ValidateEnv } from "file:///D:/dev/New%20folder/care_fe/node_modules/@julr/vite-plugin-validate-env/dist/index.mjs"; +import react from "file:///D:/dev/New%20folder/care_fe/node_modules/@vitejs/plugin-react-swc/index.mjs"; +import DOMPurify from "file:///D:/dev/New%20folder/care_fe/node_modules/dompurify/dist/purify.cjs.js"; +import fs2 from "fs"; +import { JSDOM } from "file:///D:/dev/New%20folder/care_fe/node_modules/jsdom/lib/api.js"; +import { marked } from "file:///D:/dev/New%20folder/care_fe/node_modules/marked/lib/marked.esm.js"; +import { createRequire } from "node:module"; +import path2 from "path"; +import { defineConfig, loadEnv } from "file:///D:/dev/New%20folder/care_fe/node_modules/vite/dist/node/index.js"; +import checker from "file:///D:/dev/New%20folder/care_fe/node_modules/vite-plugin-checker/dist/esm/main.js"; +import { VitePWA } from "file:///D:/dev/New%20folder/care_fe/node_modules/vite-plugin-pwa/dist/index.js"; +import { viteStaticCopy } from "file:///D:/dev/New%20folder/care_fe/node_modules/vite-plugin-static-copy/dist/index.js"; +import { z } from "file:///D:/dev/New%20folder/care_fe/node_modules/zod/lib/index.mjs"; + +// plugins/treeShakeCareIcons.ts +import * as fs from "fs"; +import { globSync } from "file:///D:/dev/New%20folder/care_fe/node_modules/glob/dist/esm/index.js"; +import * as path from "path"; +var __vite_injected_original_dirname = "D:\\dev\\New folder\\care_fe\\plugins"; +function treeShakeCareIcons(options = { iconWhitelist: [] }) { + const rootDir = path.resolve(__vite_injected_original_dirname, ".."); + const lineIconNameRegex = /"l-[a-z]+(?:-[a-z]+)*"/g; + const allUniconPaths = JSON.parse( + fs.readFileSync( + path.resolve(rootDir, "src/CAREUI/icons/UniconPaths.json"), + "utf8" + ) + ); + function extractCareIconNames(file) { + const fileContent = fs.readFileSync(file, "utf8"); + const lineIconNameMatches = fileContent.match(lineIconNameRegex) || []; + const lineIconNames = lineIconNameMatches.map( + (lineIconName) => lineIconName.slice(1, -1) + // remove quotes + ); + return lineIconNames; + } + function getAllUsedIconNames() { + const files = globSync(path.resolve(rootDir, "{apps,src}/**/*.{tsx,res}")); + const usedIconsArray = []; + files.forEach((file) => { + const iconNames = extractCareIconNames(file); + usedIconsArray.push(...iconNames); + }); + return new Set(usedIconsArray); + } + function getTreeShakenUniconPaths() { + const usedIcons = [...getAllUsedIconNames(), ...options.iconWhitelist]; + const treeshakenCareIconPaths = {}; + for (const iconName of usedIcons) { + const path3 = allUniconPaths[iconName]; + if (path3 === void 0) { + throw new Error(`Icon ${iconName} is not found in UniconPaths.json`); + } else { + treeshakenCareIconPaths[iconName] = path3; + } + } + return treeshakenCareIconPaths; + } + return { + name: "tree-shake-care-icons", + transform(_src, id) { + if (process.env.NODE_ENV !== "production") { + return; + } + if (id.endsWith("UniconPaths.json")) { + return { + code: `export default ${JSON.stringify(getTreeShakenUniconPaths())}`, + map: null + }; + } + } + }; +} + +// vite.config.mts +var __vite_injected_original_dirname2 = "D:\\dev\\New folder\\care_fe"; +var __vite_injected_original_import_meta_url = "file:///D:/dev/New%20folder/care_fe/vite.config.mts"; +var pdfWorkerPath = path2.join( + path2.dirname( + createRequire(__vite_injected_original_import_meta_url).resolve("pdfjs-dist/package.json") + ), + "build", + "pdf.worker.min.mjs" +); +function getDescriptionHtml(description) { + const html = marked.parse(description, { + async: false, + gfm: true, + breaks: true + }); + const purify = DOMPurify(new JSDOM("").window); + const sanitizedHtml = purify.sanitize(html); + return JSON.stringify(sanitizedHtml); +} +function getPluginAliases() { + const pluginsDir = path2.resolve(__vite_injected_original_dirname2, "apps"); + if (!fs2.existsSync(pluginsDir)) { + return {}; + } + const pluginFolders = fs2.readdirSync(pluginsDir); + const aliases = {}; + pluginFolders.forEach((pluginFolder) => { + const pluginSrcPath = path2.join(pluginsDir, pluginFolder, "src"); + if (fs2.existsSync(pluginSrcPath)) { + aliases[`@apps/${pluginFolder}`] = pluginSrcPath; + aliases[`@app-manifest/${pluginFolder}`] = path2.join( + pluginSrcPath, + "manifest.ts" + ); + } + }); + return aliases; +} +function getPluginDependencies() { + const pluginsDir = path2.resolve(__vite_injected_original_dirname2, "apps"); + if (!fs2.existsSync(pluginsDir)) { + return []; + } + const pluginFolders = fs2.readdirSync(pluginsDir); + const dependencies = /* @__PURE__ */ new Set(); + pluginFolders.forEach((pluginFolder) => { + const packageJsonPath = path2.join(pluginsDir, pluginFolder, "package.json"); + if (fs2.existsSync(packageJsonPath)) { + const packageJson = JSON.parse(fs2.readFileSync(packageJsonPath, "utf8")); + const pluginDependencies = packageJson.dependencies ? Object.keys(packageJson.dependencies) : []; + pluginDependencies.forEach((dep) => dependencies.add(dep)); + } + }); + return Array.from(dependencies); +} +var vite_config_default = defineConfig(({ mode }) => { + const env = loadEnv(mode, process.cwd(), ""); + const cdnUrls = env.REACT_CDN_URLS || [ + "https://egov-s3-facility-10bedicu.s3.amazonaws.com", + "https://egov-s3-patient-data-10bedicu.s3.amazonaws.com", + "http://localhost:4566" + ].join(" "); + return { + envPrefix: "REACT_", + define: { + __CUSTOM_DESCRIPTION_HTML__: getDescriptionHtml( + env.REACT_CUSTOM_DESCRIPTION || "" + ) + }, + plugins: [ + ValidateEnv({ + validator: "zod", + schema: { + REACT_CARE_API_URL: z.string().url(), + REACT_SENTRY_DSN: z.string().url().optional(), + REACT_SENTRY_ENVIRONMENT: z.string().optional(), + REACT_PLAUSIBLE_SITE_DOMAIN: z.string().regex(/^[a-zA-Z0-9][a-zA-Z0-9-_.]*\.[a-zA-Z]{2,}$/).optional().describe("Domain name without protocol (e.g., sub.domain.com)"), + REACT_PLAUSIBLE_SERVER_URL: z.string().url().optional(), + REACT_CDN_URLS: z.string().optional().transform((val) => val?.split(" ")).pipe(z.array(z.string().url()).optional()).describe("Optional: Space-separated list of CDN URLs") + } + }), + viteStaticCopy({ + targets: [ + { + src: pdfWorkerPath, + dest: "" + } + ] + }), + react(), + checker({ typescript: true }), + treeShakeCareIcons({ + iconWhitelist: ["default"] + }), + VitePWA({ + strategies: "injectManifest", + srcDir: "src", + filename: "service-worker.ts", + injectRegister: "script-defer", + devOptions: { + enabled: true, + type: "module" + }, + injectManifest: { + maximumFileSizeToCacheInBytes: 7e6 + }, + manifest: { + name: "Care", + short_name: "Care", + theme_color: "#0e9f6e", + background_color: "#ffffff", + display: "standalone", + icons: [ + { + src: "images/icons/pwa-64x64.png", + sizes: "64x64", + type: "image/png" + }, + { + src: "images/icons/pwa-192x192.png", + sizes: "192x192", + type: "image/png" + }, + { + src: "images/icons/pwa-512x512.png", + sizes: "512x512", + type: "image/png", + purpose: "any" + }, + { + src: "images/icons/maskable-icon-512x512.png", + sizes: "512x512", + type: "image/png", + purpose: "maskable" + } + ] + } + }) + ], + resolve: { + alias: { + ...getPluginAliases(), + "@": path2.resolve(__vite_injected_original_dirname2, "./src"), + "@careConfig": path2.resolve(__vite_injected_original_dirname2, "./care.config.ts"), + "@core": path2.resolve(__vite_injected_original_dirname2, "src/") + } + }, + optimizeDeps: { + include: getPluginDependencies() + }, + build: { + outDir: "build", + assetsDir: "bundle", + sourcemap: true, + rollupOptions: { + output: { + manualChunks(id, { getModuleInfo }) { + if (id.includes("node_modules")) { + let isStaticallyImportedByEntry2 = function(moduleId, visited = /* @__PURE__ */ new Set()) { + if (visited.has(moduleId)) return false; + visited.add(moduleId); + const modInfo = getModuleInfo(moduleId); + if (!modInfo) return false; + if (modInfo.isEntry) { + return true; + } + for (const importerId of modInfo.importers) { + if (isStaticallyImportedByEntry2(importerId, visited)) { + return true; + } + } + return false; + }; + var isStaticallyImportedByEntry = isStaticallyImportedByEntry2; + const moduleInfo = getModuleInfo(id); + const manualVendorChunks = /tiny-invariant/; + if (manualVendorChunks.test(id) || isStaticallyImportedByEntry2(id)) { + return "vendor"; + } else { + const dynamicImporters = moduleInfo?.dynamicImporters || []; + if (dynamicImporters && dynamicImporters.length > 0) { + const importerChunkName = dynamicImporters[0] ? dynamicImporters[0].split("/").pop() : "vendor".split(".")[0]; + return `chunk-${importerChunkName}`; + } + } + } + } + } + } + }, + server: { + port: 4e3 + }, + preview: { + headers: { + "Content-Security-Policy-Report-Only": `default-src 'self'; script-src 'self' blob: 'nonce-f51b9742' https://plausible.10bedicu.in; style-src 'self' 'unsafe-inline'; connect-src 'self' https://plausible.10bedicu.in; img-src 'self' https://cdn.ohc.network ${cdnUrls}; object-src 'self' ${cdnUrls};` + }, + port: 4e3 + } + }; +}); +export { + vite_config_default as default +}; +//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["vite.config.mts", "plugins/treeShakeCareIcons.ts"],
  "sourcesContent": ["const __vite_injected_original_dirname = \"D:\\\\dev\\\\New folder\\\\care_fe\";const __vite_injected_original_filename = \"D:\\\\dev\\\\New folder\\\\care_fe\\\\vite.config.mts\";const __vite_injected_original_import_meta_url = \"file:///D:/dev/New%20folder/care_fe/vite.config.mts\";import { ValidateEnv } from \"@julr/vite-plugin-validate-env\";\r\nimport react from \"@vitejs/plugin-react-swc\";\r\nimport DOMPurify from \"dompurify\";\r\nimport fs from \"fs\";\r\nimport { JSDOM } from \"jsdom\";\r\nimport { marked } from \"marked\";\r\nimport { createRequire } from \"node:module\";\r\nimport path from \"path\";\r\nimport { defineConfig, loadEnv } from \"vite\";\r\nimport checker from \"vite-plugin-checker\";\r\nimport { VitePWA } from \"vite-plugin-pwa\";\r\nimport { viteStaticCopy } from \"vite-plugin-static-copy\";\r\nimport { z } from \"zod\";\r\n\r\nimport { treeShakeCareIcons } from \"./plugins/treeShakeCareIcons\";\r\n\r\nconst pdfWorkerPath = path.join(\r\n  path.dirname(\r\n    createRequire(import.meta.url).resolve(\"pdfjs-dist/package.json\"),\r\n  ),\r\n  \"build\",\r\n  \"pdf.worker.min.mjs\",\r\n);\r\n\r\n// Convert goal description markdown to HTML\r\nfunction getDescriptionHtml(description: string) {\r\n  // note: escaped description causes issues with markdown parsing\r\n  const html = marked.parse(description, {\r\n    async: false,\r\n    gfm: true,\r\n    breaks: true,\r\n  });\r\n  const purify = DOMPurify(new JSDOM(\"\").window);\r\n  const sanitizedHtml = purify.sanitize(html);\r\n  return JSON.stringify(sanitizedHtml);\r\n}\r\n\r\nfunction getPluginAliases() {\r\n  const pluginsDir = path.resolve(__dirname, \"apps\");\r\n  // Make sure the `apps` folder exists\r\n  if (!fs.existsSync(pluginsDir)) {\r\n    return {};\r\n  }\r\n  const pluginFolders = fs.readdirSync(pluginsDir);\r\n\r\n  const aliases = {};\r\n\r\n  pluginFolders.forEach((pluginFolder) => {\r\n    const pluginSrcPath = path.join(pluginsDir, pluginFolder, \"src\");\r\n    if (fs.existsSync(pluginSrcPath)) {\r\n      aliases[`@apps/${pluginFolder}`] = pluginSrcPath;\r\n      aliases[`@app-manifest/${pluginFolder}`] = path.join(\r\n        pluginSrcPath,\r\n        \"manifest.ts\",\r\n      );\r\n    }\r\n  });\r\n\r\n  return aliases;\r\n}\r\n\r\nfunction getPluginDependencies(): string[] {\r\n  const pluginsDir = path.resolve(__dirname, \"apps\");\r\n  // Make sure the `apps` folder exists\r\n  if (!fs.existsSync(pluginsDir)) {\r\n    return [];\r\n  }\r\n  const pluginFolders = fs.readdirSync(pluginsDir);\r\n\r\n  const dependencies = new Set<string>();\r\n\r\n  pluginFolders.forEach((pluginFolder) => {\r\n    const packageJsonPath = path.join(pluginsDir, pluginFolder, \"package.json\");\r\n    if (fs.existsSync(packageJsonPath)) {\r\n      const packageJson = JSON.parse(fs.readFileSync(packageJsonPath, \"utf8\"));\r\n      const pluginDependencies = packageJson.dependencies\r\n        ? Object.keys(packageJson.dependencies)\r\n        : [];\r\n      pluginDependencies.forEach((dep) => dependencies.add(dep));\r\n    }\r\n  });\r\n\r\n  return Array.from(dependencies);\r\n}\r\n\r\n/** @type {import('vite').UserConfig} */\r\nexport default defineConfig(({ mode }) => {\r\n  const env = loadEnv(mode, process.cwd(), \"\");\r\n\r\n  const cdnUrls =\r\n    env.REACT_CDN_URLS ||\r\n    [\r\n      \"https://egov-s3-facility-10bedicu.s3.amazonaws.com\",\r\n      \"https://egov-s3-patient-data-10bedicu.s3.amazonaws.com\",\r\n      \"http://localhost:4566\",\r\n    ].join(\" \");\r\n\r\n  return {\r\n    envPrefix: \"REACT_\",\r\n    define: {\r\n      __CUSTOM_DESCRIPTION_HTML__: getDescriptionHtml(\r\n        env.REACT_CUSTOM_DESCRIPTION || \"\",\r\n      ),\r\n    },\r\n    plugins: [\r\n      ValidateEnv({\r\n        validator: \"zod\",\r\n        schema: {\r\n          REACT_CARE_API_URL: z.string().url(),\r\n\r\n          REACT_SENTRY_DSN: z.string().url().optional(),\r\n          REACT_SENTRY_ENVIRONMENT: z.string().optional(),\r\n\r\n          REACT_PLAUSIBLE_SITE_DOMAIN: z\r\n            .string()\r\n            .regex(/^[a-zA-Z0-9][a-zA-Z0-9-_.]*\\.[a-zA-Z]{2,}$/)\r\n            .optional()\r\n            .describe(\"Domain name without protocol (e.g., sub.domain.com)\"),\r\n\r\n          REACT_PLAUSIBLE_SERVER_URL: z.string().url().optional(),\r\n          REACT_CDN_URLS: z\r\n            .string()\r\n            .optional()\r\n            .transform((val) => val?.split(\" \"))\r\n            .pipe(z.array(z.string().url()).optional())\r\n            .describe(\"Optional: Space-separated list of CDN URLs\"),\r\n        },\r\n      }),\r\n      viteStaticCopy({\r\n        targets: [\r\n          {\r\n            src: pdfWorkerPath,\r\n            dest: \"\",\r\n          },\r\n        ],\r\n      }),\r\n      react(),\r\n      checker({ typescript: true }),\r\n      treeShakeCareIcons({\r\n        iconWhitelist: [\"default\"],\r\n      }),\r\n      VitePWA({\r\n        strategies: \"injectManifest\",\r\n        srcDir: \"src\",\r\n        filename: \"service-worker.ts\",\r\n        injectRegister: \"script-defer\",\r\n        devOptions: {\r\n          enabled: true,\r\n          type: \"module\",\r\n        },\r\n        injectManifest: {\r\n          maximumFileSizeToCacheInBytes: 7000000,\r\n        },\r\n        manifest: {\r\n          name: \"Care\",\r\n          short_name: \"Care\",\r\n          theme_color: \"#0e9f6e\",\r\n          background_color: \"#ffffff\",\r\n          display: \"standalone\",\r\n          icons: [\r\n            {\r\n              src: \"images/icons/pwa-64x64.png\",\r\n              sizes: \"64x64\",\r\n              type: \"image/png\",\r\n            },\r\n            {\r\n              src: \"images/icons/pwa-192x192.png\",\r\n              sizes: \"192x192\",\r\n              type: \"image/png\",\r\n            },\r\n            {\r\n              src: \"images/icons/pwa-512x512.png\",\r\n              sizes: \"512x512\",\r\n              type: \"image/png\",\r\n              purpose: \"any\",\r\n            },\r\n            {\r\n              src: \"images/icons/maskable-icon-512x512.png\",\r\n              sizes: \"512x512\",\r\n              type: \"image/png\",\r\n              purpose: \"maskable\",\r\n            },\r\n          ],\r\n        },\r\n      }),\r\n    ],\r\n    resolve: {\r\n      alias: {\r\n        ...getPluginAliases(),\r\n        \"@\": path.resolve(__dirname, \"./src\"),\r\n        \"@careConfig\": path.resolve(__dirname, \"./care.config.ts\"),\r\n        \"@core\": path.resolve(__dirname, \"src/\"),\r\n      },\r\n    },\r\n    optimizeDeps: {\r\n      include: getPluginDependencies(),\r\n    },\r\n    build: {\r\n      outDir: \"build\",\r\n      assetsDir: \"bundle\",\r\n      sourcemap: true,\r\n      rollupOptions: {\r\n        output: {\r\n          manualChunks(id, { getModuleInfo }) {\r\n            if (id.includes(\"node_modules\")) {\r\n              const moduleInfo = getModuleInfo(id);\r\n\r\n              // Recursive function to check if the module is statically imported by an entry point\r\n              function isStaticallyImportedByEntry(\r\n                moduleId,\r\n                visited = new Set(),\r\n              ) {\r\n                if (visited.has(moduleId)) return false;\r\n                visited.add(moduleId);\r\n\r\n                const modInfo = getModuleInfo(moduleId);\r\n                if (!modInfo) return false;\r\n\r\n                // Check if the module is an entry point\r\n                if (modInfo.isEntry) {\r\n                  return true;\r\n                }\r\n\r\n                // Check all static importers\r\n                for (const importerId of modInfo.importers) {\r\n                  if (isStaticallyImportedByEntry(importerId, visited)) {\r\n                    return true;\r\n                  }\r\n                }\r\n\r\n                return false;\r\n              }\r\n\r\n              // Determine if the module should be in the 'vendor' chunk\r\n              const manualVendorChunks = /tiny-invariant/;\r\n              if (\r\n                manualVendorChunks.test(id) ||\r\n                isStaticallyImportedByEntry(id)\r\n              ) {\r\n                return \"vendor\";\r\n              } else {\r\n                // group lazy-loaded dependencies by their dynamic importer\r\n                const dynamicImporters = moduleInfo?.dynamicImporters || [];\r\n                if (dynamicImporters && dynamicImporters.length > 0) {\r\n                  // Use the first dynamic importer to name the chunk\r\n                  const importerChunkName = dynamicImporters[0]\r\n                    ? dynamicImporters[0].split(\"/\").pop()\r\n                    : \"vendor\".split(\".\")[0];\r\n                  return `chunk-${importerChunkName}`;\r\n                }\r\n                // If no dynamic importers are found, let Rollup handle it automatically\r\n              }\r\n            }\r\n          },\r\n        },\r\n      },\r\n    },\r\n    server: {\r\n      port: 4000,\r\n    },\r\n    preview: {\r\n      headers: {\r\n        \"Content-Security-Policy-Report-Only\": `default-src 'self';\\\r\n        script-src 'self' blob: 'nonce-f51b9742' https://plausible.10bedicu.in;\\\r\n        style-src 'self' 'unsafe-inline';\\\r\n        connect-src 'self' https://plausible.10bedicu.in;\\\r\n        img-src 'self' https://cdn.ohc.network ${cdnUrls};\\\r\n        object-src 'self' ${cdnUrls};`,\r\n      },\r\n      port: 4000,\r\n    },\r\n  };\r\n});\r\n", "const __vite_injected_original_dirname = \"D:\\\\dev\\\\New folder\\\\care_fe\\\\plugins\";const __vite_injected_original_filename = \"D:\\\\dev\\\\New folder\\\\care_fe\\\\plugins\\\\treeShakeCareIcons.ts\";const __vite_injected_original_import_meta_url = \"file:///D:/dev/New%20folder/care_fe/plugins/treeShakeCareIcons.ts\";import * as fs from \"fs\";\r\nimport { globSync } from \"glob\";\r\nimport * as path from \"path\";\r\nimport { Plugin } from \"vite\";\r\n\r\n/**\r\n * Interface defining options for the treeShakeUniconPathsPlugin.\r\n *\r\n * @interface TreeShakeUniconPathsPluginOptions\r\n * @property {string[]} iconWhitelist - An array of icon names to always include, even if not found in code.\r\n */\r\n\r\nexport interface TreeShakeCareIconsOptions {\r\n  iconWhitelist: string[];\r\n}\r\n\r\n/**\r\n * Creates a Webpack plugin that tree-shakes unused Unicon paths from UniconPaths.json in production builds.\r\n *\r\n * @param {TreeShakeCareIconsOptions} [options] - Optional configuration options. Defaults to an empty iconWhitelist.\r\n * @returns {Plugin} Webpack plugin object.\r\n */\r\n\r\nexport function treeShakeCareIcons(\r\n  options: TreeShakeCareIconsOptions = { iconWhitelist: [] },\r\n): Plugin {\r\n  const rootDir = path.resolve(__dirname, \"..\"); // update this if moving this code to a different file\r\n  const lineIconNameRegex = /\"l-[a-z]+(?:-[a-z]+)*\"/g;\r\n  const allUniconPaths = JSON.parse(\r\n    fs.readFileSync(\r\n      path.resolve(rootDir, \"src/CAREUI/icons/UniconPaths.json\"),\r\n      \"utf8\",\r\n    ),\r\n  );\r\n\r\n  // Extracts icon names from a given file's content.\r\n  // Returns an array of icon names like [\"l-eye\", \"l-sync\", \"l-hearbeat\"]\r\n  function extractCareIconNames(file: string): string[] {\r\n    const fileContent = fs.readFileSync(file, \"utf8\");\r\n\r\n    const lineIconNameMatches = fileContent.match(lineIconNameRegex) || [];\r\n\r\n    const lineIconNames = lineIconNameMatches.map(\r\n      (lineIconName) => lineIconName.slice(1, -1), // remove quotes\r\n    );\r\n\r\n    return lineIconNames;\r\n  }\r\n  // Finds all used icon names within the project's source files (`.tsx` or `.res` extensions).\r\n  function getAllUsedIconNames() {\r\n    const files = globSync(path.resolve(rootDir, \"{apps,src}/**/*.{tsx,res}\"));\r\n    const usedIconsArray: string[] = [];\r\n\r\n    files.forEach((file) => {\r\n      const iconNames = extractCareIconNames(file);\r\n      usedIconsArray.push(...iconNames);\r\n    });\r\n\r\n    return new Set(usedIconsArray);\r\n  }\r\n  // Generates a map of used icon names to their paths from UniconPaths.json, including any whitelisted icons.\r\n  function getTreeShakenUniconPaths() {\r\n    const usedIcons = [...getAllUsedIconNames(), ...options.iconWhitelist];\r\n    const treeshakenCareIconPaths = {};\r\n\r\n    for (const iconName of usedIcons) {\r\n      const path = allUniconPaths[iconName];\r\n      if (path === undefined) {\r\n        throw new Error(`Icon ${iconName} is not found in UniconPaths.json`);\r\n      } else {\r\n        treeshakenCareIconPaths[iconName] = path;\r\n      }\r\n    }\r\n\r\n    return treeshakenCareIconPaths;\r\n  }\r\n\r\n  return {\r\n    name: \"tree-shake-care-icons\",\r\n    transform(_src, id) {\r\n      if (process.env.NODE_ENV !== \"production\") {\r\n        return;\r\n      }\r\n\r\n      // Replace the UniconPaths with the tree-shaken version\r\n      if (id.endsWith(\"UniconPaths.json\")) {\r\n        return {\r\n          code: `export default ${JSON.stringify(getTreeShakenUniconPaths())}`,\r\n          map: null,\r\n        };\r\n      }\r\n    },\r\n  };\r\n}\r\n"],
  "mappings": "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",
  "names": ["fs", "path", "path", "__vite_injected_original_dirname", "path", "__vite_injected_original_dirname", "fs", "isStaticallyImportedByEntry"]
}
 From 3225fe5096c5d1e087019fae6b59247b62bd063a Mon Sep 17 00:00:00 2001 From: manmeetnagii Date: Sun, 15 Dec 2024 23:16:52 +0530 Subject: [PATCH 9/9] changed dropdown to Shadcn dropdown --- src/components/Common/Export.tsx | 52 ++-- ....timestamp-1734272200960-c34409c35bb48.mjs | 282 ------------------ 2 files changed, 26 insertions(+), 308 deletions(-) delete mode 100644 vite.config.mts.timestamp-1734272200960-c34409c35bb48.mjs diff --git a/src/components/Common/Export.tsx b/src/components/Common/Export.tsx index 42efe38fd27..2c5f7849057 100644 --- a/src/components/Common/Export.tsx +++ b/src/components/Common/Export.tsx @@ -105,32 +105,32 @@ export const ExportMenu = ({ {label !== "Importing..." && ( {exportItems.map((item) => ( -
- -
{ - let action = item.action; - if (item.route) { - action = async () => { - const { data } = await request(item.route!); - return data ?? null; - }; - } - if (action) { - exportFile( - action, - item.filePrefix, - item.type, - item.parse, - ); - } - }} - > +
{ + let action = item.action; + if (item.route) { + action = async () => { + const { data } = await request(item.route!); + return data ?? null; + }; + } + if (action) { + exportFile(action, item.filePrefix, item.type, item.parse); + } + }} + {...item.options} + > + +
{item.options?.icon} {item.label}
diff --git a/vite.config.mts.timestamp-1734272200960-c34409c35bb48.mjs b/vite.config.mts.timestamp-1734272200960-c34409c35bb48.mjs deleted file mode 100644 index 7ab7e31514f..00000000000 --- a/vite.config.mts.timestamp-1734272200960-c34409c35bb48.mjs +++ /dev/null @@ -1,282 +0,0 @@ -// vite.config.mts -import { ValidateEnv } from "file:///D:/dev/New%20folder/care_fe/node_modules/@julr/vite-plugin-validate-env/dist/index.mjs"; -import react from "file:///D:/dev/New%20folder/care_fe/node_modules/@vitejs/plugin-react-swc/index.mjs"; -import DOMPurify from "file:///D:/dev/New%20folder/care_fe/node_modules/dompurify/dist/purify.cjs.js"; -import fs2 from "fs"; -import { JSDOM } from "file:///D:/dev/New%20folder/care_fe/node_modules/jsdom/lib/api.js"; -import { marked } from "file:///D:/dev/New%20folder/care_fe/node_modules/marked/lib/marked.esm.js"; -import { createRequire } from "node:module"; -import path2 from "path"; -import { defineConfig, loadEnv } from "file:///D:/dev/New%20folder/care_fe/node_modules/vite/dist/node/index.js"; -import checker from "file:///D:/dev/New%20folder/care_fe/node_modules/vite-plugin-checker/dist/esm/main.js"; -import { VitePWA } from "file:///D:/dev/New%20folder/care_fe/node_modules/vite-plugin-pwa/dist/index.js"; -import { viteStaticCopy } from "file:///D:/dev/New%20folder/care_fe/node_modules/vite-plugin-static-copy/dist/index.js"; -import { z } from "file:///D:/dev/New%20folder/care_fe/node_modules/zod/lib/index.mjs"; - -// plugins/treeShakeCareIcons.ts -import * as fs from "fs"; -import { globSync } from "file:///D:/dev/New%20folder/care_fe/node_modules/glob/dist/esm/index.js"; -import * as path from "path"; -var __vite_injected_original_dirname = "D:\\dev\\New folder\\care_fe\\plugins"; -function treeShakeCareIcons(options = { iconWhitelist: [] }) { - const rootDir = path.resolve(__vite_injected_original_dirname, ".."); - const lineIconNameRegex = /"l-[a-z]+(?:-[a-z]+)*"/g; - const allUniconPaths = JSON.parse( - fs.readFileSync( - path.resolve(rootDir, "src/CAREUI/icons/UniconPaths.json"), - "utf8" - ) - ); - function extractCareIconNames(file) { - const fileContent = fs.readFileSync(file, "utf8"); - const lineIconNameMatches = fileContent.match(lineIconNameRegex) || []; - const lineIconNames = lineIconNameMatches.map( - (lineIconName) => lineIconName.slice(1, -1) - // remove quotes - ); - return lineIconNames; - } - function getAllUsedIconNames() { - const files = globSync(path.resolve(rootDir, "{apps,src}/**/*.{tsx,res}")); - const usedIconsArray = []; - files.forEach((file) => { - const iconNames = extractCareIconNames(file); - usedIconsArray.push(...iconNames); - }); - return new Set(usedIconsArray); - } - function getTreeShakenUniconPaths() { - const usedIcons = [...getAllUsedIconNames(), ...options.iconWhitelist]; - const treeshakenCareIconPaths = {}; - for (const iconName of usedIcons) { - const path3 = allUniconPaths[iconName]; - if (path3 === void 0) { - throw new Error(`Icon ${iconName} is not found in UniconPaths.json`); - } else { - treeshakenCareIconPaths[iconName] = path3; - } - } - return treeshakenCareIconPaths; - } - return { - name: "tree-shake-care-icons", - transform(_src, id) { - if (process.env.NODE_ENV !== "production") { - return; - } - if (id.endsWith("UniconPaths.json")) { - return { - code: `export default ${JSON.stringify(getTreeShakenUniconPaths())}`, - map: null - }; - } - } - }; -} - -// vite.config.mts -var __vite_injected_original_dirname2 = "D:\\dev\\New folder\\care_fe"; -var __vite_injected_original_import_meta_url = "file:///D:/dev/New%20folder/care_fe/vite.config.mts"; -var pdfWorkerPath = path2.join( - path2.dirname( - createRequire(__vite_injected_original_import_meta_url).resolve("pdfjs-dist/package.json") - ), - "build", - "pdf.worker.min.mjs" -); -function getDescriptionHtml(description) { - const html = marked.parse(description, { - async: false, - gfm: true, - breaks: true - }); - const purify = DOMPurify(new JSDOM("").window); - const sanitizedHtml = purify.sanitize(html); - return JSON.stringify(sanitizedHtml); -} -function getPluginAliases() { - const pluginsDir = path2.resolve(__vite_injected_original_dirname2, "apps"); - if (!fs2.existsSync(pluginsDir)) { - return {}; - } - const pluginFolders = fs2.readdirSync(pluginsDir); - const aliases = {}; - pluginFolders.forEach((pluginFolder) => { - const pluginSrcPath = path2.join(pluginsDir, pluginFolder, "src"); - if (fs2.existsSync(pluginSrcPath)) { - aliases[`@apps/${pluginFolder}`] = pluginSrcPath; - aliases[`@app-manifest/${pluginFolder}`] = path2.join( - pluginSrcPath, - "manifest.ts" - ); - } - }); - return aliases; -} -function getPluginDependencies() { - const pluginsDir = path2.resolve(__vite_injected_original_dirname2, "apps"); - if (!fs2.existsSync(pluginsDir)) { - return []; - } - const pluginFolders = fs2.readdirSync(pluginsDir); - const dependencies = /* @__PURE__ */ new Set(); - pluginFolders.forEach((pluginFolder) => { - const packageJsonPath = path2.join(pluginsDir, pluginFolder, "package.json"); - if (fs2.existsSync(packageJsonPath)) { - const packageJson = JSON.parse(fs2.readFileSync(packageJsonPath, "utf8")); - const pluginDependencies = packageJson.dependencies ? Object.keys(packageJson.dependencies) : []; - pluginDependencies.forEach((dep) => dependencies.add(dep)); - } - }); - return Array.from(dependencies); -} -var vite_config_default = defineConfig(({ mode }) => { - const env = loadEnv(mode, process.cwd(), ""); - const cdnUrls = env.REACT_CDN_URLS || [ - "https://egov-s3-facility-10bedicu.s3.amazonaws.com", - "https://egov-s3-patient-data-10bedicu.s3.amazonaws.com", - "http://localhost:4566" - ].join(" "); - return { - envPrefix: "REACT_", - define: { - __CUSTOM_DESCRIPTION_HTML__: getDescriptionHtml( - env.REACT_CUSTOM_DESCRIPTION || "" - ) - }, - plugins: [ - ValidateEnv({ - validator: "zod", - schema: { - REACT_CARE_API_URL: z.string().url(), - REACT_SENTRY_DSN: z.string().url().optional(), - REACT_SENTRY_ENVIRONMENT: z.string().optional(), - REACT_PLAUSIBLE_SITE_DOMAIN: z.string().regex(/^[a-zA-Z0-9][a-zA-Z0-9-_.]*\.[a-zA-Z]{2,}$/).optional().describe("Domain name without protocol (e.g., sub.domain.com)"), - REACT_PLAUSIBLE_SERVER_URL: z.string().url().optional(), - REACT_CDN_URLS: z.string().optional().transform((val) => val?.split(" ")).pipe(z.array(z.string().url()).optional()).describe("Optional: Space-separated list of CDN URLs") - } - }), - viteStaticCopy({ - targets: [ - { - src: pdfWorkerPath, - dest: "" - } - ] - }), - react(), - checker({ typescript: true }), - treeShakeCareIcons({ - iconWhitelist: ["default"] - }), - VitePWA({ - strategies: "injectManifest", - srcDir: "src", - filename: "service-worker.ts", - injectRegister: "script-defer", - devOptions: { - enabled: true, - type: "module" - }, - injectManifest: { - maximumFileSizeToCacheInBytes: 7e6 - }, - manifest: { - name: "Care", - short_name: "Care", - theme_color: "#0e9f6e", - background_color: "#ffffff", - display: "standalone", - icons: [ - { - src: "images/icons/pwa-64x64.png", - sizes: "64x64", - type: "image/png" - }, - { - src: "images/icons/pwa-192x192.png", - sizes: "192x192", - type: "image/png" - }, - { - src: "images/icons/pwa-512x512.png", - sizes: "512x512", - type: "image/png", - purpose: "any" - }, - { - src: "images/icons/maskable-icon-512x512.png", - sizes: "512x512", - type: "image/png", - purpose: "maskable" - } - ] - } - }) - ], - resolve: { - alias: { - ...getPluginAliases(), - "@": path2.resolve(__vite_injected_original_dirname2, "./src"), - "@careConfig": path2.resolve(__vite_injected_original_dirname2, "./care.config.ts"), - "@core": path2.resolve(__vite_injected_original_dirname2, "src/") - } - }, - optimizeDeps: { - include: getPluginDependencies() - }, - build: { - outDir: "build", - assetsDir: "bundle", - sourcemap: true, - rollupOptions: { - output: { - manualChunks(id, { getModuleInfo }) { - if (id.includes("node_modules")) { - let isStaticallyImportedByEntry2 = function(moduleId, visited = /* @__PURE__ */ new Set()) { - if (visited.has(moduleId)) return false; - visited.add(moduleId); - const modInfo = getModuleInfo(moduleId); - if (!modInfo) return false; - if (modInfo.isEntry) { - return true; - } - for (const importerId of modInfo.importers) { - if (isStaticallyImportedByEntry2(importerId, visited)) { - return true; - } - } - return false; - }; - var isStaticallyImportedByEntry = isStaticallyImportedByEntry2; - const moduleInfo = getModuleInfo(id); - const manualVendorChunks = /tiny-invariant/; - if (manualVendorChunks.test(id) || isStaticallyImportedByEntry2(id)) { - return "vendor"; - } else { - const dynamicImporters = moduleInfo?.dynamicImporters || []; - if (dynamicImporters && dynamicImporters.length > 0) { - const importerChunkName = dynamicImporters[0] ? dynamicImporters[0].split("/").pop() : "vendor".split(".")[0]; - return `chunk-${importerChunkName}`; - } - } - } - } - } - } - }, - server: { - port: 4e3 - }, - preview: { - headers: { - "Content-Security-Policy-Report-Only": `default-src 'self'; script-src 'self' blob: 'nonce-f51b9742' https://plausible.10bedicu.in; style-src 'self' 'unsafe-inline'; connect-src 'self' https://plausible.10bedicu.in; img-src 'self' https://cdn.ohc.network ${cdnUrls}; object-src 'self' ${cdnUrls};` - }, - port: 4e3 - } - }; -}); -export { - vite_config_default as default -}; -//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["vite.config.mts", "plugins/treeShakeCareIcons.ts"],
  "sourcesContent": ["const __vite_injected_original_dirname = \"D:\\\\dev\\\\New folder\\\\care_fe\";const __vite_injected_original_filename = \"D:\\\\dev\\\\New folder\\\\care_fe\\\\vite.config.mts\";const __vite_injected_original_import_meta_url = \"file:///D:/dev/New%20folder/care_fe/vite.config.mts\";import { ValidateEnv } from \"@julr/vite-plugin-validate-env\";\r\nimport react from \"@vitejs/plugin-react-swc\";\r\nimport DOMPurify from \"dompurify\";\r\nimport fs from \"fs\";\r\nimport { JSDOM } from \"jsdom\";\r\nimport { marked } from \"marked\";\r\nimport { createRequire } from \"node:module\";\r\nimport path from \"path\";\r\nimport { defineConfig, loadEnv } from \"vite\";\r\nimport checker from \"vite-plugin-checker\";\r\nimport { VitePWA } from \"vite-plugin-pwa\";\r\nimport { viteStaticCopy } from \"vite-plugin-static-copy\";\r\nimport { z } from \"zod\";\r\n\r\nimport { treeShakeCareIcons } from \"./plugins/treeShakeCareIcons\";\r\n\r\nconst pdfWorkerPath = path.join(\r\n  path.dirname(\r\n    createRequire(import.meta.url).resolve(\"pdfjs-dist/package.json\"),\r\n  ),\r\n  \"build\",\r\n  \"pdf.worker.min.mjs\",\r\n);\r\n\r\n// Convert goal description markdown to HTML\r\nfunction getDescriptionHtml(description: string) {\r\n  // note: escaped description causes issues with markdown parsing\r\n  const html = marked.parse(description, {\r\n    async: false,\r\n    gfm: true,\r\n    breaks: true,\r\n  });\r\n  const purify = DOMPurify(new JSDOM(\"\").window);\r\n  const sanitizedHtml = purify.sanitize(html);\r\n  return JSON.stringify(sanitizedHtml);\r\n}\r\n\r\nfunction getPluginAliases() {\r\n  const pluginsDir = path.resolve(__dirname, \"apps\");\r\n  // Make sure the `apps` folder exists\r\n  if (!fs.existsSync(pluginsDir)) {\r\n    return {};\r\n  }\r\n  const pluginFolders = fs.readdirSync(pluginsDir);\r\n\r\n  const aliases = {};\r\n\r\n  pluginFolders.forEach((pluginFolder) => {\r\n    const pluginSrcPath = path.join(pluginsDir, pluginFolder, \"src\");\r\n    if (fs.existsSync(pluginSrcPath)) {\r\n      aliases[`@apps/${pluginFolder}`] = pluginSrcPath;\r\n      aliases[`@app-manifest/${pluginFolder}`] = path.join(\r\n        pluginSrcPath,\r\n        \"manifest.ts\",\r\n      );\r\n    }\r\n  });\r\n\r\n  return aliases;\r\n}\r\n\r\nfunction getPluginDependencies(): string[] {\r\n  const pluginsDir = path.resolve(__dirname, \"apps\");\r\n  // Make sure the `apps` folder exists\r\n  if (!fs.existsSync(pluginsDir)) {\r\n    return [];\r\n  }\r\n  const pluginFolders = fs.readdirSync(pluginsDir);\r\n\r\n  const dependencies = new Set<string>();\r\n\r\n  pluginFolders.forEach((pluginFolder) => {\r\n    const packageJsonPath = path.join(pluginsDir, pluginFolder, \"package.json\");\r\n    if (fs.existsSync(packageJsonPath)) {\r\n      const packageJson = JSON.parse(fs.readFileSync(packageJsonPath, \"utf8\"));\r\n      const pluginDependencies = packageJson.dependencies\r\n        ? Object.keys(packageJson.dependencies)\r\n        : [];\r\n      pluginDependencies.forEach((dep) => dependencies.add(dep));\r\n    }\r\n  });\r\n\r\n  return Array.from(dependencies);\r\n}\r\n\r\n/** @type {import('vite').UserConfig} */\r\nexport default defineConfig(({ mode }) => {\r\n  const env = loadEnv(mode, process.cwd(), \"\");\r\n\r\n  const cdnUrls =\r\n    env.REACT_CDN_URLS ||\r\n    [\r\n      \"https://egov-s3-facility-10bedicu.s3.amazonaws.com\",\r\n      \"https://egov-s3-patient-data-10bedicu.s3.amazonaws.com\",\r\n      \"http://localhost:4566\",\r\n    ].join(\" \");\r\n\r\n  return {\r\n    envPrefix: \"REACT_\",\r\n    define: {\r\n      __CUSTOM_DESCRIPTION_HTML__: getDescriptionHtml(\r\n        env.REACT_CUSTOM_DESCRIPTION || \"\",\r\n      ),\r\n    },\r\n    plugins: [\r\n      ValidateEnv({\r\n        validator: \"zod\",\r\n        schema: {\r\n          REACT_CARE_API_URL: z.string().url(),\r\n\r\n          REACT_SENTRY_DSN: z.string().url().optional(),\r\n          REACT_SENTRY_ENVIRONMENT: z.string().optional(),\r\n\r\n          REACT_PLAUSIBLE_SITE_DOMAIN: z\r\n            .string()\r\n            .regex(/^[a-zA-Z0-9][a-zA-Z0-9-_.]*\\.[a-zA-Z]{2,}$/)\r\n            .optional()\r\n            .describe(\"Domain name without protocol (e.g., sub.domain.com)\"),\r\n\r\n          REACT_PLAUSIBLE_SERVER_URL: z.string().url().optional(),\r\n          REACT_CDN_URLS: z\r\n            .string()\r\n            .optional()\r\n            .transform((val) => val?.split(\" \"))\r\n            .pipe(z.array(z.string().url()).optional())\r\n            .describe(\"Optional: Space-separated list of CDN URLs\"),\r\n        },\r\n      }),\r\n      viteStaticCopy({\r\n        targets: [\r\n          {\r\n            src: pdfWorkerPath,\r\n            dest: \"\",\r\n          },\r\n        ],\r\n      }),\r\n      react(),\r\n      checker({ typescript: true }),\r\n      treeShakeCareIcons({\r\n        iconWhitelist: [\"default\"],\r\n      }),\r\n      VitePWA({\r\n        strategies: \"injectManifest\",\r\n        srcDir: \"src\",\r\n        filename: \"service-worker.ts\",\r\n        injectRegister: \"script-defer\",\r\n        devOptions: {\r\n          enabled: true,\r\n          type: \"module\",\r\n        },\r\n        injectManifest: {\r\n          maximumFileSizeToCacheInBytes: 7000000,\r\n        },\r\n        manifest: {\r\n          name: \"Care\",\r\n          short_name: \"Care\",\r\n          theme_color: \"#0e9f6e\",\r\n          background_color: \"#ffffff\",\r\n          display: \"standalone\",\r\n          icons: [\r\n            {\r\n              src: \"images/icons/pwa-64x64.png\",\r\n              sizes: \"64x64\",\r\n              type: \"image/png\",\r\n            },\r\n            {\r\n              src: \"images/icons/pwa-192x192.png\",\r\n              sizes: \"192x192\",\r\n              type: \"image/png\",\r\n            },\r\n            {\r\n              src: \"images/icons/pwa-512x512.png\",\r\n              sizes: \"512x512\",\r\n              type: \"image/png\",\r\n              purpose: \"any\",\r\n            },\r\n            {\r\n              src: \"images/icons/maskable-icon-512x512.png\",\r\n              sizes: \"512x512\",\r\n              type: \"image/png\",\r\n              purpose: \"maskable\",\r\n            },\r\n          ],\r\n        },\r\n      }),\r\n    ],\r\n    resolve: {\r\n      alias: {\r\n        ...getPluginAliases(),\r\n        \"@\": path.resolve(__dirname, \"./src\"),\r\n        \"@careConfig\": path.resolve(__dirname, \"./care.config.ts\"),\r\n        \"@core\": path.resolve(__dirname, \"src/\"),\r\n      },\r\n    },\r\n    optimizeDeps: {\r\n      include: getPluginDependencies(),\r\n    },\r\n    build: {\r\n      outDir: \"build\",\r\n      assetsDir: \"bundle\",\r\n      sourcemap: true,\r\n      rollupOptions: {\r\n        output: {\r\n          manualChunks(id, { getModuleInfo }) {\r\n            if (id.includes(\"node_modules\")) {\r\n              const moduleInfo = getModuleInfo(id);\r\n\r\n              // Recursive function to check if the module is statically imported by an entry point\r\n              function isStaticallyImportedByEntry(\r\n                moduleId,\r\n                visited = new Set(),\r\n              ) {\r\n                if (visited.has(moduleId)) return false;\r\n                visited.add(moduleId);\r\n\r\n                const modInfo = getModuleInfo(moduleId);\r\n                if (!modInfo) return false;\r\n\r\n                // Check if the module is an entry point\r\n                if (modInfo.isEntry) {\r\n                  return true;\r\n                }\r\n\r\n                // Check all static importers\r\n                for (const importerId of modInfo.importers) {\r\n                  if (isStaticallyImportedByEntry(importerId, visited)) {\r\n                    return true;\r\n                  }\r\n                }\r\n\r\n                return false;\r\n              }\r\n\r\n              // Determine if the module should be in the 'vendor' chunk\r\n              const manualVendorChunks = /tiny-invariant/;\r\n              if (\r\n                manualVendorChunks.test(id) ||\r\n                isStaticallyImportedByEntry(id)\r\n              ) {\r\n                return \"vendor\";\r\n              } else {\r\n                // group lazy-loaded dependencies by their dynamic importer\r\n                const dynamicImporters = moduleInfo?.dynamicImporters || [];\r\n                if (dynamicImporters && dynamicImporters.length > 0) {\r\n                  // Use the first dynamic importer to name the chunk\r\n                  const importerChunkName = dynamicImporters[0]\r\n                    ? dynamicImporters[0].split(\"/\").pop()\r\n                    : \"vendor\".split(\".\")[0];\r\n                  return `chunk-${importerChunkName}`;\r\n                }\r\n                // If no dynamic importers are found, let Rollup handle it automatically\r\n              }\r\n            }\r\n          },\r\n        },\r\n      },\r\n    },\r\n    server: {\r\n      port: 4000,\r\n    },\r\n    preview: {\r\n      headers: {\r\n        \"Content-Security-Policy-Report-Only\": `default-src 'self';\\\r\n        script-src 'self' blob: 'nonce-f51b9742' https://plausible.10bedicu.in;\\\r\n        style-src 'self' 'unsafe-inline';\\\r\n        connect-src 'self' https://plausible.10bedicu.in;\\\r\n        img-src 'self' https://cdn.ohc.network ${cdnUrls};\\\r\n        object-src 'self' ${cdnUrls};`,\r\n      },\r\n      port: 4000,\r\n    },\r\n  };\r\n});\r\n", "const __vite_injected_original_dirname = \"D:\\\\dev\\\\New folder\\\\care_fe\\\\plugins\";const __vite_injected_original_filename = \"D:\\\\dev\\\\New folder\\\\care_fe\\\\plugins\\\\treeShakeCareIcons.ts\";const __vite_injected_original_import_meta_url = \"file:///D:/dev/New%20folder/care_fe/plugins/treeShakeCareIcons.ts\";import * as fs from \"fs\";\r\nimport { globSync } from \"glob\";\r\nimport * as path from \"path\";\r\nimport { Plugin } from \"vite\";\r\n\r\n/**\r\n * Interface defining options for the treeShakeUniconPathsPlugin.\r\n *\r\n * @interface TreeShakeUniconPathsPluginOptions\r\n * @property {string[]} iconWhitelist - An array of icon names to always include, even if not found in code.\r\n */\r\n\r\nexport interface TreeShakeCareIconsOptions {\r\n  iconWhitelist: string[];\r\n}\r\n\r\n/**\r\n * Creates a Webpack plugin that tree-shakes unused Unicon paths from UniconPaths.json in production builds.\r\n *\r\n * @param {TreeShakeCareIconsOptions} [options] - Optional configuration options. Defaults to an empty iconWhitelist.\r\n * @returns {Plugin} Webpack plugin object.\r\n */\r\n\r\nexport function treeShakeCareIcons(\r\n  options: TreeShakeCareIconsOptions = { iconWhitelist: [] },\r\n): Plugin {\r\n  const rootDir = path.resolve(__dirname, \"..\"); // update this if moving this code to a different file\r\n  const lineIconNameRegex = /\"l-[a-z]+(?:-[a-z]+)*\"/g;\r\n  const allUniconPaths = JSON.parse(\r\n    fs.readFileSync(\r\n      path.resolve(rootDir, \"src/CAREUI/icons/UniconPaths.json\"),\r\n      \"utf8\",\r\n    ),\r\n  );\r\n\r\n  // Extracts icon names from a given file's content.\r\n  // Returns an array of icon names like [\"l-eye\", \"l-sync\", \"l-hearbeat\"]\r\n  function extractCareIconNames(file: string): string[] {\r\n    const fileContent = fs.readFileSync(file, \"utf8\");\r\n\r\n    const lineIconNameMatches = fileContent.match(lineIconNameRegex) || [];\r\n\r\n    const lineIconNames = lineIconNameMatches.map(\r\n      (lineIconName) => lineIconName.slice(1, -1), // remove quotes\r\n    );\r\n\r\n    return lineIconNames;\r\n  }\r\n  // Finds all used icon names within the project's source files (`.tsx` or `.res` extensions).\r\n  function getAllUsedIconNames() {\r\n    const files = globSync(path.resolve(rootDir, \"{apps,src}/**/*.{tsx,res}\"));\r\n    const usedIconsArray: string[] = [];\r\n\r\n    files.forEach((file) => {\r\n      const iconNames = extractCareIconNames(file);\r\n      usedIconsArray.push(...iconNames);\r\n    });\r\n\r\n    return new Set(usedIconsArray);\r\n  }\r\n  // Generates a map of used icon names to their paths from UniconPaths.json, including any whitelisted icons.\r\n  function getTreeShakenUniconPaths() {\r\n    const usedIcons = [...getAllUsedIconNames(), ...options.iconWhitelist];\r\n    const treeshakenCareIconPaths = {};\r\n\r\n    for (const iconName of usedIcons) {\r\n      const path = allUniconPaths[iconName];\r\n      if (path === undefined) {\r\n        throw new Error(`Icon ${iconName} is not found in UniconPaths.json`);\r\n      } else {\r\n        treeshakenCareIconPaths[iconName] = path;\r\n      }\r\n    }\r\n\r\n    return treeshakenCareIconPaths;\r\n  }\r\n\r\n  return {\r\n    name: \"tree-shake-care-icons\",\r\n    transform(_src, id) {\r\n      if (process.env.NODE_ENV !== \"production\") {\r\n        return;\r\n      }\r\n\r\n      // Replace the UniconPaths with the tree-shaken version\r\n      if (id.endsWith(\"UniconPaths.json\")) {\r\n        return {\r\n          code: `export default ${JSON.stringify(getTreeShakenUniconPaths())}`,\r\n          map: null,\r\n        };\r\n      }\r\n    },\r\n  };\r\n}\r\n"],
  "mappings": "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",
  "names": ["fs", "path", "path", "__vite_injected_original_dirname", "path", "__vite_injected_original_dirname", "fs", "isStaticallyImportedByEntry"]
}
