@rxdrag/website-lib-react 0.0.3 → 0.0.6

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (97) hide show
  1. package/dist/ReactModalTrigger-9207e763.js +26 -0
  2. package/dist/ReactModalTrigger-9207e763.js.map +1 -0
  3. package/dist/components/RichTextOutline/parseOutline.d.ts +5 -0
  4. package/dist/components/all.d.ts +0 -21
  5. package/dist/components/index.d.ts +0 -5
  6. package/dist/forms.d.ts +1 -0
  7. package/dist/forms.mjs +1647 -0
  8. package/dist/forms.mjs.map +1 -0
  9. package/dist/index.mjs +9 -3918
  10. package/dist/index.mjs.map +1 -1
  11. package/dist/jsx-runtime-c02cc059.js +325 -0
  12. package/dist/jsx-runtime-c02cc059.js.map +1 -0
  13. package/dist/media.d.ts +1 -0
  14. package/dist/media.mjs +613 -0
  15. package/dist/media.mjs.map +1 -0
  16. package/dist/richtext.d.ts +1 -0
  17. package/dist/richtext.mjs +191 -0
  18. package/dist/richtext.mjs.map +1 -0
  19. package/dist/ui.d.ts +10 -0
  20. package/dist/ui.mjs +687 -0
  21. package/dist/ui.mjs.map +1 -0
  22. package/dist/video.d.ts +2 -0
  23. package/dist/video.mjs +426 -0
  24. package/dist/video.mjs.map +1 -0
  25. package/forms.ts +1 -0
  26. package/index.ts +1 -0
  27. package/media.ts +1 -0
  28. package/package.json +41 -6
  29. package/richtext.ts +1 -0
  30. package/src/components/Analytics/eventHandlers.ts +173 -0
  31. package/src/components/Analytics/index.tsx +21 -0
  32. package/src/components/Analytics/singleton.ts +214 -0
  33. package/src/components/Analytics/tracking.ts +221 -0
  34. package/src/components/Analytics/types.ts +60 -0
  35. package/src/components/Analytics/utils.ts +95 -0
  36. package/src/components/AttachmentIcon/index.tsx +53 -0
  37. package/src/components/BackgroundHlsVideoPlayer.tsx +97 -0
  38. package/src/components/BackgroundVideoPlayer.tsx +32 -0
  39. package/src/components/Bulletin.tsx +30 -0
  40. package/src/components/ContactForm/ContactForm.tsx +290 -0
  41. package/src/components/ContactForm/FileUpload2.tsx +423 -0
  42. package/src/components/ContactForm/Input.tsx +48 -0
  43. package/src/components/ContactForm/Input2.tsx +59 -0
  44. package/src/components/ContactForm/Submit.tsx +48 -0
  45. package/src/components/ContactForm/TelInput.tsx +215 -0
  46. package/src/components/ContactForm/TelInput2.tsx +213 -0
  47. package/src/components/ContactForm/Textarea.tsx +48 -0
  48. package/src/components/ContactForm/Textarea2.tsx +89 -0
  49. package/src/components/ContactForm/countryDialCodes.ts +243 -0
  50. package/src/components/ContactForm/factory.tsx +60 -0
  51. package/src/components/ContactForm/funcs.ts +64 -0
  52. package/src/components/ContactForm/hooks/useInlineLabelPadding.ts +43 -0
  53. package/src/components/ContactForm/hooks/useTelControl.ts +81 -0
  54. package/src/components/ContactForm/index.ts +7 -0
  55. package/src/components/ContactForm/types.ts +68 -0
  56. package/src/components/Icon/index.tsx +20 -0
  57. package/src/components/Medias/MainMedia.tsx +257 -0
  58. package/src/components/Medias/Thumbnail.tsx +62 -0
  59. package/src/components/Medias/VideoPlayer.tsx +114 -0
  60. package/src/components/Medias/index.tsx +271 -0
  61. package/src/components/ProductCard/ProductCard.tsx +24 -0
  62. package/src/components/ProductCard/ProductCta/index.tsx +28 -0
  63. package/src/components/ProductCard/ProductCta/style.css +4 -0
  64. package/src/components/ProductCard/ProductDescription/index.tsx +13 -0
  65. package/src/components/ProductCard/ProductDescription/style.css +6 -0
  66. package/src/components/ProductCard/ProductMedia/index.tsx +35 -0
  67. package/src/components/ProductCard/ProductMedia/style.css +6 -0
  68. package/src/components/ProductCard/ProductTitle/index.tsx +7 -0
  69. package/src/components/ProductCard/ProductTitle/style.css +4 -0
  70. package/src/components/ProductCard/ProductView.tsx +36 -0
  71. package/src/components/ProductCard/index.ts +5 -0
  72. package/src/components/ProductCard/useQueryProduct.ts +32 -0
  73. package/src/components/ReactModalTrigger.tsx +28 -0
  74. package/src/components/ReactVideoPlayer.tsx +332 -0
  75. package/src/components/RichTextOutline/index.tsx +74 -0
  76. package/src/components/RichTextOutline/parseOutline.ts +63 -0
  77. package/src/components/RichTextOutline/useAcitviedHeading.ts +142 -0
  78. package/src/components/RichTextOutline/useAnchorScroll.ts +24 -0
  79. package/src/components/Scroller.tsx +39 -0
  80. package/src/components/SearchInput.tsx +21 -0
  81. package/src/components/Share/index.tsx +86 -0
  82. package/src/components/Share/socials.tsx +80 -0
  83. package/src/components/Share//350/265/204/346/226/231.md +7 -0
  84. package/src/components/ToTop.tsx +72 -0
  85. package/src/components/VideoPlayIcon.tsx +43 -0
  86. package/src/components/all.ts +25 -0
  87. package/src/components/index.ts +12 -0
  88. package/src/forms.ts +1 -0
  89. package/src/index.ts +1 -0
  90. package/src/media.ts +1 -0
  91. package/src/richtext.ts +1 -0
  92. package/src/types/view-model.ts +37 -0
  93. package/src/ui.ts +10 -0
  94. package/src/video.ts +2 -0
  95. package/ui.ts +1 -0
  96. package/video.ts +1 -0
  97. package/dist/style.css +0 -17
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ui.mjs","sources":["../src/components/Analytics/utils.ts","../src/components/Analytics/tracking.ts","../src/components/Analytics/singleton.ts","../src/components/Analytics/index.tsx","../src/components/AttachmentIcon/index.tsx","../src/components/Icon/index.tsx","../src/components/Share/socials.tsx","../src/components/Share/index.tsx","../src/components/Scroller.tsx","../src/components/SearchInput.tsx","../src/components/ToTop.tsx","../src/components/BackgroundVideoPlayer.tsx","../src/components/Bulletin.tsx"],"sourcesContent":["// Analytics 工具函数\n\n// 检查是否为开发环境\nexport function isDevelopmentEnvironment(): boolean {\n return (\n window.location.hostname === \"localhost\" ||\n window.location.hostname.startsWith(\"192.168.\") ||\n window.location.hostname === \"127.0.0.1\"\n );\n}\n\n// 调试日志函数\nexport function createDebugLogger() {\n const isDev = isDevelopmentEnvironment();\n return function debugLog(...args: unknown[]) {\n if (isDev) {\n console.log(\"[Analytics]\", ...args);\n }\n };\n}\n\n// 生成唯一 ID(简单版)\nexport function generateId(prefix = \"v\"): string {\n return (\n prefix +\n Date.now().toString(36) +\n Math.random().toString(36).substring(2, 8)\n );\n}\n\n// 设置 cookie\nexport function setCookie(name: string, value: string, days: number): void {\n const expires = new Date();\n expires.setTime(expires.getTime() + days * 24 * 60 * 60 * 1000);\n document.cookie = `${name}=${value};expires=${expires.toUTCString()};path=/;SameSite=Lax`;\n}\n\n// 获取 cookie\nexport function getCookie(name: string): string | null {\n const match = document.cookie.match(\n new RegExp(\"(^| )\" + name + \"=([^;]+)\")\n );\n return match ? match[2] : null;\n}\n\n// 获取或生成 visitor_id(长期存储)\nexport function getVisitorId(): string {\n let visitorId = getCookie(\"visitor_id\");\n if (!visitorId) {\n visitorId = generateId(\"v\");\n setCookie(\"visitor_id\", visitorId, 365); // 365天有效\n }\n return visitorId;\n}\n\n// 获取设备信息\nexport function getDeviceInfo(): string {\n const ua = navigator.userAgent;\n if (/Mobile|Android|iPhone|iPad/.test(ua)) {\n return /iPad/.test(ua) ? \"tablet\" : \"mobile\";\n }\n return \"desktop\";\n}\n\n// 获取平台信息\nexport function getPlatform(): string {\n const ua = navigator.userAgent;\n if (/Windows/.test(ua)) return \"Windows\";\n if (/Mac/.test(ua)) return \"macOS\";\n if (/Linux/.test(ua)) return \"Linux\";\n if (/Android/.test(ua)) return \"Android\";\n if (/iPhone|iPad/.test(ua)) return \"iOS\";\n return \"Unknown\";\n}\n\n// 获取浏览器语言\nexport function getBrowserLanguage(): string {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n return navigator.language || (navigator as any).userLanguage || \"en\";\n}\n\n// 检测页面类型\nexport function detectPageType(defaultType = \"pageView\"): string {\n const currentPath = window.location.pathname.toLowerCase();\n\n // 检测是否为 thanks 页面\n if (\n currentPath.includes(\"/thanks\") ||\n currentPath.includes(\"/thank-you\")\n ) {\n return \"enquiry\";\n }\n\n return defaultType;\n}\n","// Analytics 跟踪相关函数\nimport type { AnalyticsState, PageData, TrackingData } from './types';\nimport { \n getDeviceInfo, \n getPlatform, \n getBrowserLanguage, \n detectPageType,\n getCookie \n} from './utils';\n\n// 更新活跃时间\nexport function updateActiveTime(state: AnalyticsState): void {\n if (state.isPageVisible) {\n const now = Date.now();\n state.activeTime += now - state.lastActiveTime;\n state.lastActiveTime = now;\n }\n}\n\n// 重置页面跟踪(用于页面切换)\nexport function resetPageTracking(state: AnalyticsState, pageData: PageData): void {\n const newUrl = window.location.href;\n // 只有当 URL 真正改变时才重置\n if (newUrl !== state.currentPageUrl) {\n state.currentPageUrl = newUrl;\n pageData.start_time = Date.now();\n state.pageLoadTime = Date.now();\n state.isPageTracked = false;\n // 重置活跃时间追踪\n state.activeTime = 0;\n state.lastActiveTime = Date.now();\n state.isPageVisible = !document.hidden;\n }\n}\n\n// 检查是否为真正的页面访问(简化版)\nexport function isRealPageVisit(state: AnalyticsState): boolean {\n const now = Date.now();\n\n // 如果页面已经被跟踪过,则不是新访问\n if (state.isPageTracked) {\n return false;\n }\n\n // 检查是否在短时间内重复跟踪(全局防重复)\n if (state.lastTrackTime > 0 && now - state.lastTrackTime < 1000) {\n return false;\n }\n\n // 检查页面是否可见(避免在后台标签页中统计)\n if (document.hidden || document.visibilityState === \"hidden\") {\n return false;\n }\n\n return true;\n}\n\n// 处理队列中的下一个请求\nexport function processQueue(state: AnalyticsState, apiEndpoint: string): void {\n state.isRequestPending = false;\n\n if (state.requestQueue.length > 0) {\n const { data, eventType } = state.requestQueue.shift()!;\n // 小延迟避免请求过于频繁\n setTimeout(() => {\n sendImmediately(data, eventType, state, apiEndpoint);\n }, 100);\n }\n}\n\n// 立即发送数据\nexport function sendImmediately(\n data: TrackingData, \n eventType: string, \n state: AnalyticsState, \n apiEndpoint: string\n): void {\n state.isRequestPending = true;\n\n fetch(apiEndpoint, {\n method: \"POST\",\n headers: {\n \"Content-Type\": \"application/json\",\n \"X-Requested-With\": \"XMLHttpRequest\",\n },\n body: JSON.stringify(data),\n keepalive: true,\n })\n .then(() => {\n if (eventType === \"pageView\") {\n state.isPageTracked = true;\n state.lastTrackTime = Date.now();\n \n // 更新全局状态(用于跨组件实例共享)\n if (typeof window !== 'undefined') {\n (window as any).__analyticsGlobalState = {\n lastPageUrl: window.location.href,\n lastTrackTime: Date.now(),\n };\n }\n }\n\n // 处理队列中的下一个请求\n processQueue(state, apiEndpoint);\n })\n .catch(() => {\n processQueue(state, apiEndpoint);\n });\n}\n\n// 优化的网络请求函数\nexport function sendTrackingData(\n data: TrackingData, \n eventType: string, \n state: AnalyticsState, \n apiEndpoint: string\n): void {\n // 对于 pageLeave 事件,立即发送(用户可能马上离开)\n if (eventType === \"pageLeave\") {\n sendImmediately(data, eventType, state, apiEndpoint);\n return;\n }\n\n // 对于 pageView 事件,可以稍微延迟或批量处理\n if (state.isRequestPending) {\n // 如果有请求正在进行,加入队列\n state.requestQueue.push({ data, eventType });\n return;\n }\n\n sendImmediately(data, eventType, state, apiEndpoint);\n}\n\n// 创建跟踪数据\nexport function createTrackingData(\n pageData: PageData,\n state: AnalyticsState,\n eventType: string,\n effectiveDuration: number\n): TrackingData {\n return {\n visitor_id: pageData.visitor_id,\n session_id: pageData.session_id,\n url: window.location.href,\n path: window.location.pathname,\n referrer: state.currentReferrer,\n user_agent: pageData.user_agent,\n duration_ms: effectiveDuration, // 使用活跃时间\n timestamp: Date.now(),\n type: eventType, // 添加事件类型\n // 设备和平台信息\n device: getDeviceInfo(),\n platform: getPlatform(),\n browser_language: getBrowserLanguage(),\n // 页面信息\n page_title: document.title || null,\n // 屏幕信息\n screen_width: screen.width,\n screen_height: screen.height,\n viewport_width: window.innerWidth,\n viewport_height: window.innerHeight,\n // 时区信息\n timezone: Intl.DateTimeFormat().resolvedOptions().timeZone,\n // 是否新用户(简单判断:第一次访问该域名)\n is_new_user:\n !getCookie(\"visitor_id\") ||\n getCookie(\"visitor_id\") === pageData.visitor_id,\n };\n}\n\n// 发送访客数据(支持不同类型)\nexport function trackPageEvent(\n eventType: string,\n pageData: PageData,\n state: AnalyticsState,\n apiEndpoint: string,\n debugLog: (...args: any[]) => void\n): void {\n // 对于 pageView 事件,检测页面类型\n if (eventType === \"pageView\") {\n eventType = detectPageType(eventType);\n debugLog(\"Detected page type:\", eventType);\n\n // 检查是否为真正的页面访问\n if (!isRealPageVisit(state)) {\n return;\n }\n }\n\n // 计算活跃时间\n let effectiveDuration = 0;\n if (eventType === \"pageLeave\") {\n updateActiveTime(state); // 更新到当前时间\n effectiveDuration = state.activeTime;\n }\n\n debugLog(\"Using referrer:\", state.currentReferrer, \"for event:\", eventType);\n\n const data = createTrackingData(pageData, state, eventType, effectiveDuration);\n\n // 优化的网络请求处理\n sendTrackingData(data, eventType, state, apiEndpoint);\n}\n\n// 兼容性函数,保持向后兼容\nexport function trackPageVisit(\n pageData: PageData,\n state: AnalyticsState,\n apiEndpoint: string,\n debugLog: (...args: any[]) => void\n): void {\n // 检查是否在短时间内(200ms)重复调用同一个 URL 的 pageView\n const currentUrl = window.location.href;\n const now = Date.now();\n \n if (state.isPageTracked && state.currentPageUrl === currentUrl && now - state.lastTrackTime < 200) {\n return;\n }\n \n trackPageEvent(\"pageView\", pageData, state, apiEndpoint, debugLog);\n}\n","// Analytics 单例管理器\nimport type { AnalyticsState, PageData } from './types';\nimport { \n createDebugLogger, \n generateId, \n getVisitorId \n} from './utils';\nimport { trackPageEvent } from './tracking';\n\nclass AnalyticsSingleton {\n private static instance: AnalyticsSingleton | null = null;\n private initialized = false;\n private state: AnalyticsState;\n private pageData: PageData;\n private apiEndpoint: string;\n private debugLog: (...args: any[]) => void;\n private eventHandlers: Array<() => void> = [];\n\n private constructor(apiEndpoint: string) {\n this.apiEndpoint = apiEndpoint;\n this.debugLog = createDebugLogger();\n \n // 初始化访客和会话信息\n const visitorId = getVisitorId();\n let sessionId = sessionStorage.getItem('session_id');\n if (!sessionId) {\n sessionId = generateId('s');\n sessionStorage.setItem('session_id', sessionId);\n }\n\n // 页面信息\n this.pageData = {\n visitor_id: visitorId,\n session_id: sessionId,\n url: window.location.href,\n path: window.location.pathname,\n referrer: document.referrer || null,\n user_agent: navigator.userAgent,\n start_time: Date.now(),\n };\n\n // 状态管理\n this.state = {\n isPageTracked: false,\n currentPageUrl: window.location.href,\n pageLoadTime: Date.now(),\n lastTrackTime: 0,\n currentReferrer: document.referrer || null,\n activeTime: 0,\n lastActiveTime: Date.now(),\n isPageVisible: !document.hidden,\n requestQueue: [],\n isRequestPending: false,\n isAstroEnvironment: false,\n pageLeaveTracked: false,\n initialLoadHandled: false,\n interactionThrottled: false,\n lastInteractionTime: 0,\n };\n\n }\n\n static getInstance(apiEndpoint = \"/api/track-visitor\"): AnalyticsSingleton {\n if (!AnalyticsSingleton.instance) {\n AnalyticsSingleton.instance = new AnalyticsSingleton(apiEndpoint);\n }\n return AnalyticsSingleton.instance;\n }\n\n static reset(): void {\n if (AnalyticsSingleton.instance) {\n AnalyticsSingleton.instance.cleanup();\n AnalyticsSingleton.instance = null;\n }\n }\n\n init(): void {\n if (this.initialized) {\n return;\n }\n\n this.initialized = true;\n this.setupEventListeners();\n this.handleInitialPageLoad();\n }\n\n private setupEventListeners(): void {\n // 页面离开事件\n const handlePageLeave = () => {\n if (this.state.pageLeaveTracked || this.state.lastTrackTime === 0) {\n return;\n }\n\n this.state.pageLeaveTracked = true;\n trackPageEvent(\"pageLeave\", this.pageData, this.state, this.apiEndpoint, this.debugLog);\n };\n\n // 页面离开事件监听器\n const handleBeforeUnload = () => handlePageLeave();\n const handlePageHide = () => handlePageLeave();\n\n window.addEventListener('beforeunload', handleBeforeUnload);\n window.addEventListener('pagehide', handlePageHide);\n\n // Astro 事件监听\n const handleAstroBeforeSwap = () => {\n handlePageLeave();\n };\n\n const handleAstroAfterSwap = () => {\n this.state.isAstroEnvironment = true;\n\n const newUrl = window.location.href;\n if (newUrl !== this.state.currentPageUrl) {\n // 更新 referrer:页面切换时,referrer 是上一个页面\n this.state.currentReferrer = this.state.currentPageUrl;\n\n // 更新页面状态\n this.state.currentPageUrl = newUrl;\n this.pageData.url = newUrl;\n this.pageData.path = window.location.pathname;\n this.pageData.start_time = Date.now();\n this.state.pageLoadTime = Date.now();\n this.state.isPageTracked = false;\n this.state.pageLeaveTracked = false;\n this.state.activeTime = 0;\n this.state.lastActiveTime = Date.now();\n this.state.isPageVisible = !document.hidden;\n\n // 发送新页面统计\n this.trackPageVisit();\n }\n };\n\n document.addEventListener('astro:before-swap', handleAstroBeforeSwap);\n document.addEventListener('astro:after-swap', handleAstroAfterSwap);\n\n // 页面可见性变化\n const handleVisibilityChange = () => {\n const now = Date.now();\n if (document.visibilityState === 'visible') {\n this.state.isPageVisible = true;\n this.state.lastActiveTime = now;\n } else {\n if (this.state.isPageVisible) {\n this.state.activeTime += now - this.state.lastActiveTime;\n }\n this.state.isPageVisible = false;\n }\n };\n\n document.addEventListener('visibilitychange', handleVisibilityChange);\n\n // 用户交互事件\n const handleUserInteraction = () => {\n if (!this.state.isPageVisible || this.state.interactionThrottled) return;\n\n const now = Date.now();\n if (now - this.state.lastInteractionTime < 1000) return;\n\n this.state.lastInteractionTime = now;\n this.state.interactionThrottled = true;\n\n if (now - this.state.lastActiveTime > 30000) {\n this.state.lastActiveTime = now;\n }\n\n setTimeout(() => {\n this.state.interactionThrottled = false;\n }, 1000);\n };\n\n const interactionEvents = ['click', 'keydown', 'scroll'];\n interactionEvents.forEach((event) => {\n document.addEventListener(event, handleUserInteraction, {\n passive: true,\n capture: false,\n });\n });\n\n // 保存事件处理器引用,用于清理\n this.eventHandlers = [\n () => window.removeEventListener('beforeunload', handleBeforeUnload),\n () => window.removeEventListener('pagehide', handlePageHide),\n () => document.removeEventListener('astro:before-swap', handleAstroBeforeSwap),\n () => document.removeEventListener('astro:after-swap', handleAstroAfterSwap),\n () => document.removeEventListener('visibilitychange', handleVisibilityChange),\n ...interactionEvents.map(event => \n () => document.removeEventListener(event, handleUserInteraction)\n )\n ];\n }\n\n private handleInitialPageLoad(): void {\n if (this.state.isPageTracked || this.state.initialLoadHandled) {\n return;\n }\n\n this.state.initialLoadHandled = true;\n this.trackPageVisit();\n }\n\n private trackPageVisit(): void {\n trackPageEvent(\"pageView\", this.pageData, this.state, this.apiEndpoint, this.debugLog);\n }\n\n cleanup(): void {\n this.eventHandlers.forEach(cleanup => cleanup());\n this.eventHandlers = [];\n this.initialized = false;\n }\n}\n\nexport default AnalyticsSingleton;\n","import { useEffect } from 'react';\nimport type { AnalyticsProps } from './types';\nimport AnalyticsSingleton from './singleton';\n\nexport function Analytics({\n apiEndpoint = \"/api/track-visitor\"\n}: AnalyticsProps) {\n useEffect(() => {\n // 获取单例实例并初始化\n const analytics = AnalyticsSingleton.getInstance(apiEndpoint);\n analytics.init();\n\n // 组件卸载时不清理单例,让它继续工作\n return () => {\n // 不做任何清理,让单例继续工作\n };\n }, [apiEndpoint]);\n\n // 组件不渲染任何可见内容\n return null;\n}\n","import { forwardRef } from \"react\";\n\nexport type AttachmentIconProps = {\n extName?: string;\n className?: string;\n};\n\nexport const AttachmentIcon = forwardRef<HTMLDivElement, AttachmentIconProps>(\n (props, ref) => {\n const { extName, ...rest } = props;\n return (\n <div ref={ref} {...rest}>\n {extName && extName === \".pdf\" ? (\n <svg\n fill=\"currentColor\"\n viewBox=\"0 0 1024 1024\"\n version=\"1.1\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path d=\"M905.185809 178.844158C898.576738 172.685485 891.19337 165.824412 883.21687 158.436127 860.422682 137.322863 837.434925 116.207791 815.697647 96.487895 813.243072 94.261877 813.243072 94.261877 810.786411 92.037081 781.783552 65.781062 757.590948 44.376502 739.713617 29.293612 729.254178 20.469111 721.020606 13.860686 714.970549 9.501727 710.955023 6.608611 707.690543 4.524745 704.47155 2.998714 700.417679 1.07689 696.638044-0.094029 691.307277 0.005928 677.045677 0.273349 665.6 11.769337 665.6 26.182727L665.6 77.352844 665.6 128.522961 665.6 230.863194 665.6 256.448252 691.2 256.448252 896 256.448252 870.4 230.863194 870.4 998.414942 896 972.829884 230.381436 972.829884C187.90385 972.829884 153.6 938.623723 153.6 896.20663L153.6 26.182727 128 51.767786 588.8 51.767786C602.93849 51.767786 614.4 40.312965 614.4 26.182727 614.4 12.05249 602.93849 0.597669 588.8 0.597669L128 0.597669 102.4 0.597669 102.4 26.182727 102.4 896.20663C102.4 966.91021 159.652833 1024 230.381436 1024L896 1024 921.6 1024 921.6 998.414942 921.6 230.863194 921.6 205.278135 896 205.278135 691.2 205.278135 716.8 230.863194 716.8 128.522961 716.8 77.352844 716.8 26.182727C716.8 39.813762 705.748075 50.91427 692.267725 51.167041 687.705707 51.252584 685.069822 50.435995 682.52845 49.231204 682.259458 49.103682 683.344977 49.796618 685.029451 51.010252 689.779394 54.432502 697.145822 60.34494 706.686383 68.394196 724.009052 83.009121 747.816448 104.072869 776.413589 129.961594 778.850014 132.168064 778.850014 132.168064 781.285216 134.376514 802.876774 153.964212 825.739479 174.96442 848.413564 195.966437 856.350957 203.3185 863.697005 210.144893 870.269888 216.269843 874.209847 219.941299 877.019309 222.565641 878.499674 223.951409 888.81866 233.610931 905.019017 233.081212 914.684179 222.768247 924.349344 212.455283 923.819315 196.264383 913.500326 186.604861 911.981323 185.182945 909.155025 182.542876 905.185809 178.844158ZM102.4 461.128719 0 461.128719 0 896.074709 512 896.074709 1024 896.074709 1024 461.128719 153.6 461.128719 153.6 460.531049 102.4 460.531049 102.4 461.128719ZM208.2 711 208.2 819.2 157.6 819.2 157.6 528 269 528C301.533495 528 327.366571 536.466581 346.5 553.4 365.633429 570.333419 375.2 592.733195 375.2 620.6 375.2 649.133476 365.833427 671.333254 347.1 687.2 328.366573 703.066746 302.133502 711 268.4 711L208.2 711ZM208.2 670.4 269 670.4C287.00009 670.4 300.733286 666.166709 310.2 657.7 319.666714 649.233291 324.4 637.000079 324.4 621 324.4 605.266588 319.600047 592.700047 310 583.3 300.399951 573.899953 287.200083 569.066669 270.4 568.8L208.2 568.8 208.2 670.4ZM419.4 819.2 419.4 528 505.4 528C531.133461 528 553.966566 533.733276 573.9 545.2 593.833434 556.666724 609.266611 572.933229 620.2 594 631.133389 615.066771 636.6 639.199863 636.6 666.4L636.6 681C636.6 708.600139 631.100055 732.866562 620.1 753.8 609.099945 774.733438 593.433436 790.866609 573.1 802.2 552.766564 813.533391 529.466799 819.2 503.2 819.2L419.4 819.2ZM470 568.8 470 778.8 503 778.8C529.533466 778.8 549.89993 770.500083 564.1 753.9 578.30007 737.299917 585.533331 713.466822 585.8 682.4L585.8 666.2C585.8 634.599842 578.933402 610.46675 565.2 593.8 551.466598 577.13325 531.533463 568.8 505.4 568.8L470 568.8ZM854.8 695.8 737.6 695.8 737.6 819.2 687 819.2 687 528 872 528 872 568.8 737.6 568.8 737.6 655.4 854.8 655.4 854.8 695.8Z\" />\n </svg>\n ) : extName && (extName === \".xls\" || extName === \".xlsx\") ? (\n <svg\n fill=\"currentColor\"\n viewBox=\"0 0 1024 1024\"\n version=\"1.1\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path d=\"M810.18 949.8H213.821c-20.551 0-37.271-16.649-37.271-37.1V111.3c0-20.45 16.72-37.1 37.271-37.1h395.27v143.74c0 52.25 46.97 94.77 104.71 94.77h133.65V912.7c0 20.451-16.72 37.1-37.27 37.1zM678.9 118.68l130.85 130.85H713.8c-19.25 0-34.9-14.169-34.9-31.59v-99.26z m168.551 55.41l-99.89-99.89L673.36 0H213.82C152.16 0 102 49.93 102 111.3v801.4c0 61.371 50.16 111.3 111.821 111.3h596.36C871.84 1024 922 974.071 922 912.7V248.64l-74.55-74.55z\" />\n <path d=\"M810.18 949.8H213.821c-20.551 0-37.271-16.649-37.271-37.1V111.3c0-20.45 16.72-37.1 37.271-37.1h395.27v143.74c0 52.25 46.97 94.77 104.71 94.77h133.65V912.7c0 20.451-16.72 37.1-37.27 37.1zM678.9 118.68l130.85 130.85H713.8c-19.25 0-34.9-14.169-34.9-31.59v-99.26z m168.551 55.41l-99.89-99.89L673.36 0H213.82C152.16 0 102 49.93 102 111.3v801.4c0 61.371 50.16 111.3 111.821 111.3h596.36C871.84 1024 922 974.071 922 912.7V248.64l-74.55-74.55z\" />\n <path d=\"M559.714 579.272L668.11 404.855a0.2 0.2 0 0 0-0.17-0.305h-89.12a0.2 0.2 0 0 0-0.174 0.102l-67.604 120.3-70.265-120.303a0.2 0.2 0 0 0-0.173-0.1h-85.779a0.2 0.2 0 0 0-0.168 0.308L461.02 571.401 347.653 746.24a0.2 0.2 0 0 0 0.168 0.309h88.007a0.2 0.2 0 0 0 0.17-0.095l74.362-120.51 75.153 120.51a0.2 0.2 0 0 0 0.17 0.095h89.835a0.2 0.2 0 0 0 0.164-0.314L559.714 579.272z\" />\n </svg>\n ) : extName && (extName === \".doc\" || extName === \".docx\") ? (\n <svg\n fill=\"currentColor\"\n viewBox=\"0 0 1024 1024\"\n version=\"1.1\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path d=\"M854.6 288.6L639.4 73.4c-6-6-14.1-9.4-22.6-9.4H192c-17.7 0-32 14.3-32 32v832c0 17.7 14.3 32 32 32h640c17.7 0 32-14.3 32-32V311.3c0-8.5-3.4-16.7-9.4-22.7zM790.2 326H602V137.8L790.2 326z m1.8 562H232V136h302v216c0 23.2 18.8 42 42 42h216v494zM528.1 472h-32.2c-5.5 0-10.3 3.7-11.6 9.1L434.6 680l-46.1-198.7c-1.3-5.4-6.1-9.3-11.7-9.3h-35.4c-1.1 0-2.1 0.1-3.1 0.4-6.4 1.7-10.2 8.3-8.5 14.7l74.2 276c1.4 5.2 6.2 8.9 11.6 8.9h32c5.4 0 10.2-3.6 11.6-8.9l52.8-197 52.8 197c1.4 5.2 6.2 8.9 11.6 8.9h31.8c5.4 0 10.2-3.6 11.6-8.9l74.4-276c0.3-1 0.4-2.1 0.4-3.1 0-6.6-5.4-12-12-12H647c-5.6 0-10.4 3.9-11.7 9.3l-45.8 199.1-49.8-199.3c-1.3-5.4-6.1-9.1-11.6-9.1z\" />\n </svg>\n ) : (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\">\n <path\n fill=\"currentColor\"\n d=\"M14 11a3 3 0 0 1-3-3V4H7a2 2 0 0 0-2 2v13a2 2 0 0 0 2 2h9a2 2 0 0 0 2-2v-8zm-2-3a2 2 0 0 0 2 2h3.59L12 4.41zM7 3h5l7 7v9a3 3 0 0 1-3 3H7a3 3 0 0 1-3-3V6a3 3 0 0 1 3-3\"\n />\n </svg>\n )}\n </div>\n );\n }\n);\n","import {\n Icon as IconifyIcon,\n IconProps as IconifyIconProps,\n} from \"@iconify/react\";\nimport type { IconifyIcon as IconifyIconData } from \"@iconify/react\";\nimport { forwardRef } from \"react\";\n\nexport type IconProps = Omit<IconifyIconProps, \"icon\"> & {\n icon?: string | IconifyIconData;\n};\n\nexport const Icon = forwardRef<SVGSVGElement, IconProps>((props, ref) => {\n const { icon, ...rest } = props;\n\n if (!icon) {\n return null;\n }\n\n return <IconifyIcon ref={ref} {...rest} icon={icon} />;\n});","import React from \"react\";\n\nexport interface IconListType {\n [key: string]: {\n title: string;\n path: React.ReactElement;\n url: (l: string, t?: string, ti?: string) => string;\n color: string;\n viewBox?: string;\n };\n}\n\nexport const iconList: IconListType = {\n linkedin: {\n title: \"LinkedIn\",\n path: (\n <path d=\"M6.5 21.5h-5v-13h5v13zM4 6.5C2.5 6.5 1.5 5.3 1.5 4s1-2.4 2.5-2.4c1.6 0 2.5 1 2.6 2.5 0 1.4-1 2.5-2.6 2.5zm11.5 6c-1 0-2 1-2 2v7h-5v-13h5V10s1.6-1.5 4-1.5c3 0 5 2.2 5 6.3v6.7h-5v-7c0-1-1-2-2-2z\" />\n ),\n color: \"#0073b1\",\n url: (l, t, ti) =>\n `https://www.linkedin.com/sharing/share-offsite/?url=${encodeURIComponent(l)}&title=${encodeURIComponent(ti || \"\")}&summary=${encodeURIComponent(t || \"\")}`,\n },\n facebook: {\n title: \"Facebook\",\n path: (\n <path d=\"M24 12a12 12 0 10-13.9 11.9v-8.4h-3V12h3V9.4c0-3 1.8-4.7 4.6-4.7l2.6.2v3h-1.5c-1.5 0-2 .9-2 1.8V12h3.4l-.5 3.5h-2.8v8.4A12 12 0 0024 12z\" />\n ),\n color: \"#0076FB\",\n url: (l) => `https://www.facebook.com/sharer/sharer.php?u=${encodeURIComponent(l)}`,\n },\n twitter: {\n title: \"X\",\n path: (\n <path d=\"M18.244 2.25h3.308l-7.227 8.26 8.502 11.24H16.17l-5.214-6.817L4.99 21.75H1.68l7.73-8.835L1.254 2.25H8.08l4.713 6.231zm-1.161 17.52h1.833L7.084 4.126H5.117z\"></path>\n ),\n color: \"#0F1419\",\n url: (l, t) => `https://twitter.com/intent/tweet?text=${t}&url=${encodeURIComponent(l)}`,\n },\n whatsapp: {\n title: \"WhatsApp\",\n path: (\n <path d=\"M17.5 14.4l-2-1c-.3 0-.5-.1-.7.2l-1 1.1c-.1.2-.3.3-.6.1s-1.3-.5-2.4-1.5a9 9 0 01-1.7-2c-.1-.3 0-.5.2-.6l.4-.6c.2-.1.2-.3.3-.5v-.5L9 7c-.2-.6-.4-.5-.6-.5h-.6c-.2 0-.5 0-.8.4-.2.3-1 1-1 2.5s1 2.8 1.2 3c.2.2 2.1 3.2 5.1 4.5l1.7.6a4 4 0 001.9.2c.5-.1 1.7-.8 2-1.5.2-.6.2-1.2.1-1.4l-.5-.3M12 21.8a9.9 9.9 0 01-5-1.4l-.4-.2-3.7 1 1-3.7-.2-.3a9.9 9.9 0 01-1.5-5.3 9.9 9.9 0 0116.8-7 9.8 9.8 0 013 7 9.9 9.9 0 01-10 9.9m8.4-18.3A11.8 11.8 0 0012.1 0 12 12 0 001.8 17.8L0 24l6.4-1.6a11.9 11.9 0 005.6 1.4 12 12 0 0012-11.9 11.8 11.8 0 00-3.5-8.4z\" />\n ),\n color: \"#25D366\",\n url: (l, t) => `https://api.whatsapp.com/send?text=${encodeURIComponent(t || \"\")} ${encodeURIComponent(l)}`,\n },\n reddit: {\n title: \"Reddit\",\n path: (\n <path d=\"M12 0A12 12 0 000 12a12 12 0 0012 12 12 12 0 0012-12A12 12 0 0012 0zm5.01 4.74c.69 0 1.25.56 1.25 1.25a1.25 1.25 0 01-2.5.06l-2.6-.55-.8 3.75c1.83.07 3.48.63 4.68 1.49.3-.31.73-.5 1.2-.5.97 0 1.76.8 1.76 1.76 0 .72-.43 1.33-1.01 1.61a3.11 3.11 0 01.04.52c0 2.7-3.13 4.87-7 4.87-3.88 0-7-2.17-7-4.87 0-.18 0-.36.04-.53A1.75 1.75 0 014.03 12a1.75 1.75 0 012.96-1.26 8.52 8.52 0 014.74-1.5l.89-4.17a.34.34 0 01.14-.2.35.35 0 01.24-.04l2.9.62a1.21 1.21 0 011.11-.7zM9.25 12a1.25 1.25 0 101.25 1.25c0-.69-.56-1.25-1.25-1.25zm5.5 0a1.25 1.25 0 000 2.5 1.25 1.25 0 000-2.5zm-5.47 3.99a.33.33 0 00-.23.1.33.33 0 000 .46c.84.84 2.49.91 2.96.91.48 0 2.1-.06 2.96-.91a.36.36 0 00.03-.47.33.33 0 00-.46 0c-.55.54-1.68.73-2.51.73-.83 0-1.98-.2-2.51-.73a.33.33 0 00-.24-.1z\" />\n ),\n color: \"#FF4500\",\n url: (l, t) => `https://www.reddit.com/submit?url=${encodeURIComponent(l)}&title=${encodeURIComponent(t || \"\")}`,\n },\n // telegram: {\n // title: \"Telegram\",\n // path: (\n // <path d=\"M23.91 3.79L20.3 20.84c-.25 1.21-.98 1.5-2 .94l-5.5-4.07-2.66 2.57c-.3.3-.55.56-1.1.56-.72 0-.6-.27-.84-.95L6.3 13.7.85 12c-1.18-.35-1.19-1.16.26-1.75l21.26-8.2c.97-.43 1.9.24 1.53 1.73z\" />\n // ),\n // color: \"#0088CC\",\n // url: (l, t) => `https://telegram.me/share/msg?url=${encodeURIComponent(l)}&text=${encodeURIComponent(t || \"\")}`,\n // },\n\n // pinterest: {\n // title: \"Pinterest\",\n // path: (\n // <path d=\"M0 12C0 17.123 3.211 21.497 7.73 23.218C7.62 22.281 7.503 20.736 7.755 19.652C7.972 18.72 9.156 13.714 9.156 13.714C9.156 13.714 8.799 12.999 8.799 11.94C8.799 10.28 9.761 9.04 10.96 9.04C11.98 9.04 12.472 9.805 12.472 10.722C12.472 11.747 11.819 13.279 11.482 14.7C11.201 15.889 12.079 16.859 13.251 16.859C15.374 16.859 17.007 14.62 17.007 11.388C17.007 8.527 14.951 6.528 12.016 6.528C8.618 6.528 6.623 9.077 6.623 11.712C6.623 12.739 7.018 13.839 7.512 14.438C7.55412 14.4832 7.58387 14.5386 7.59841 14.5986C7.61295 14.6587 7.61177 14.7215 7.595 14.781C7.504 15.159 7.302 15.97 7.263 16.136C7.21 16.354 7.09 16.401 6.863 16.295C5.371 15.601 4.439 13.42 4.439 11.668C4.439 7.899 7.176 4.439 12.331 4.439C16.475 4.439 19.696 7.392 19.696 11.338C19.696 15.455 17.101 18.769 13.497 18.769C12.286 18.769 11.149 18.139 10.759 17.396C10.759 17.396 10.16 19.678 10.015 20.236C9.733 21.32 8.951 22.692 8.466 23.471C9.584 23.815 10.77 24 12 24C18.627 24 24 18.627 24 12C24 5.373 18.627 0 12 0C5.373 0 0 5.373 0 12Z\" />\n // ),\n // color: \"#c8232c\",\n // url: (l) => `http://pinterest.com/pin/create/link/?url=${encodeURIComponent(l)}`,\n // },\n // email: {\n // title: \"Email\",\n // path: (\n // <path d=\"M20 4H4a2 2 0 00-2 2v12c0 1.1.9 2 2 2h16a2 2 0 002-2V6a2 2 0 00-2-2zm0 4l-8 5-8-5V6l8 5 8-5v2z\" />\n // ),\n // color: \"#E53E3E\",\n // url: (l, t) => `mailto:?body=${encodeURIComponent(l)}&subject=${encodeURIComponent(t || \"\")}`,\n // },\n};","import { forwardRef, useEffect, useState } from \"react\";\nimport type { IconListType } from \"./socials\";\nimport { iconList } from \"./socials\";\nimport clsx from \"clsx\";\n\nexport type ShareProps = {\n socials?: string[];\n size?: \"xs\" | \"sm\" | \"md\" | \"lg\" | \"xl\";\n className?: string;\n classNames?: {\n item?: string;\n itemIcon?: string;\n };\n};\n\nfunction getPageDetails() {\n if (typeof window === \"undefined\") {\n return null;\n }\n const details = {\n url: window?.location?.href,\n title: document?.title || \"null\",\n description: \"null\", // 默认为空字符串\n };\n\n const descriptionMetaTag = document.querySelector('meta[name=\"description\"]');\n if (descriptionMetaTag) {\n details.description = (descriptionMetaTag as HTMLMetaElement).content;\n }\n\n return details;\n}\n\nexport const Share = forwardRef<HTMLDivElement, ShareProps>(\n (props: ShareProps, ref) => {\n const { className, classNames, ...rest } = props;\n const [socialList, setSolicalList] = useState<IconListType>();\n\n const details = getPageDetails();\n\n useEffect(() => {\n setSolicalList(iconList);\n }, [props.socials]);\n\n // 生成每个社交媒体的分享链接\n const generateLink = (key: string) => {\n const social = iconList[key];\n if (!social) return \"#\";\n return social.url(\n details?.url || \"\",\n details?.title,\n details?.description\n );\n };\n\n return (\n <div ref={ref} className={clsx(\"flex items-center\", className)} {...rest}>\n <div className=\"flex space-x-3\">\n {Object.keys(socialList || {}).map((key) => (\n <a\n key={key}\n href={generateLink(key)}\n target=\"_blank\"\n rel=\"noopener noreferrer\"\n title={`Share on ${iconList[key].title}`}\n className={clsx(\n \"flex h-6 w-6 items-center justify-center \",\n classNames?.item\n )}\n >\n <svg\n className={clsx(\"w-5 h-5\", classNames?.itemIcon)}\n fill=\"currentColor\"\n viewBox=\"0 0 24 24\"\n focusable=\"false\"\n aria-hidden=\"true\"\n >\n {iconList[key].path}\n </svg>\n </a>\n ))}\n </div>\n </div>\n );\n }\n);\n","import { useCallback, useEffect, useRef, useState } from \"react\";\n\nexport const defaultThreshold = 10;\n\nexport type ScrollerProps = {\n threshold?: number;\n};\n\nexport function Scroller(props: ScrollerProps) {\n const { threshold = defaultThreshold } = props;\n const ref = useRef<HTMLDivElement>(null);\n const [win, setWin] = useState<Window | null>(null);\n\n useEffect(() => {\n if (ref.current) {\n setWin(ref.current.ownerDocument.defaultView);\n }\n }, []);\n\n const onScroll = useCallback(() => {\n if (!win) return;\n const scrolled = win.scrollY > threshold;\n const doc = win.document;\n\n if (scrolled) {\n doc.body.classList.add(\"scrolled\");\n } else {\n doc.body.classList.remove(\"scrolled\");\n }\n }, [threshold, win]);\n\n useEffect(() => {\n if (!win) return;\n win.addEventListener(\"scroll\", onScroll);\n return () => win.removeEventListener(\"scroll\", onScroll);\n }, [onScroll, win]);\n\n return <div ref={ref} style={{ display: \"none\" }} />;\n}\n","import { forwardRef, useState } from \"react\";\n\nexport type SearchProps = React.InputHTMLAttributes<HTMLInputElement>;\n\nexport const SearchInput = forwardRef<HTMLInputElement, SearchProps>(\n (props, ref) => {\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n const { children, ...rest } = props;\n const [keyword, setKeyword] = useState<string>();\n\n return (\n <input\n ref={ref}\n name=\"q\"\n value={keyword}\n onChange={(e) => setKeyword(e.target.value)}\n {...rest}\n />\n );\n }\n);\n","import clsx from \"clsx\";\nimport { forwardRef, useRef, useEffect, useState } from \"react\";\n\nexport type ToTopProps = {\n className?: string;\n svg?: string;\n};\n\nexport const topIcon = () => (\n <svg\n className=\"h-6 w-6\"\n width=\"1.5rem\"\n height=\"1.5rem\"\n fill=\"none\"\n viewBox=\"0 0 24 24\"\n stroke=\"currentColor\"\n >\n <path\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n strokeWidth={2}\n d=\"M5 15l7-7 7 7\"\n />\n </svg>\n);\n\nexport const ToTop = forwardRef<HTMLDivElement, ToTopProps>((props, ref) => {\n const { className, svg, ...rest } = props;\n const [win, setWin] = useState<Window | null>(null);\n const innerRef = useRef<HTMLDivElement>(null);\n\n // 合并外部传入的ref和内部ref\n useEffect(() => {\n if (!innerRef.current) return;\n\n // 获取当前元素所在的window\n const currentWin = innerRef.current.ownerDocument.defaultView;\n setWin(currentWin);\n\n // 如果外部传入的是ref对象,则设置其current属性\n if (ref && typeof ref === \"object\") {\n ref.current = innerRef.current;\n }\n }, [ref]);\n\n const handleClick = () => {\n if (win) {\n win.scrollTo({ top: 0, behavior: \"smooth\" });\n } else if (typeof window !== \"undefined\") {\n // 降级处理:如果没有获取到特定window,使用全局window\n window.scrollTo({ top: 0, behavior: \"smooth\" });\n }\n };\n\n return (\n <div\n ref={innerRef}\n className={clsx(\n \"fixed bottom-4 right-4 hidden user-select-none shadow-lg scrolled:flex cursor-pointer transition duration-300 ease-in-out z-50\",\n className\n )}\n {...rest}\n onClick={handleClick}\n >\n {svg ? (\n <div className=\"contents\" dangerouslySetInnerHTML={{ __html: svg }} />\n ) : (\n topIcon()\n )}\n </div>\n );\n});\n","import { useEffect, useRef, type VideoHTMLAttributes } from \"react\";\n\nexport function BackgroundVideoPlayer(props: VideoHTMLAttributes<HTMLVideoElement>) {\n const { poster, src, className, ...restProps } = props;\n const videoRef = useRef<HTMLVideoElement>(null);\n\n useEffect(() => {\n if (videoRef.current) {\n const video = videoRef.current;\n\n // 确保视频可以自动播放\n video.play().catch((error) => {\n console.log(\"自动播放失败:\", error);\n });\n }\n }, []);\n\n return (\n <video\n ref={videoRef}\n autoPlay\n loop\n muted\n playsInline\n poster={poster}\n className={className}\n preload=\"metadata\"\n src={src}\n {...restProps}\n ></video>\n );\n}\n","import { Bulletin as BulletinModel } from \"@rxdrag/rxcms-models\";\nimport { useEffect, useState } from \"react\";\n\nexport function Bulletin(props: { className?: string }) {\n const { className, ...rest } = props;\n const [bulletin, setBulletin] = useState<BulletinModel | null>(null);\n\n useEffect(() => {\n fetch(\"/api/get-bulletin\")\n .then((res) => res.json())\n .then((res) => {\n if (res.success) {\n setBulletin(res.data);\n }\n })\n .catch((err) => {\n console.error(\"Failed to fetch bulletin\", err);\n });\n }, []);\n\n console.log(\"====>bulletin\", bulletin)\n\n if (!bulletin) return null;\n\n return (\n <div className={className} {...rest}>\n {bulletin.content}\n </div>\n );\n}\n"],"names":["jsx","jsxs","IconifyIcon"],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export * from './components/BackgroundHlsVideoPlayer';
2
+ export * from './components/ReactVideoPlayer';
package/dist/video.mjs ADDED
@@ -0,0 +1,426 @@
1
+ import { j as jsxRuntimeExports } from "./jsx-runtime-c02cc059.js";
2
+ import { useRef, useEffect, forwardRef, useState, useCallback } from "react";
3
+ import Hls from "hls.js";
4
+ import { R as ReactModalTrigger } from "./ReactModalTrigger-9207e763.js";
5
+ import clsx$1, { clsx } from "clsx";
6
+ const FORBIDDEN_PROPS = /* @__PURE__ */ new Set([
7
+ "createMetadata",
8
+ "createComponent",
9
+ "createAstro",
10
+ "renderComponent",
11
+ "renderSlot",
12
+ "render",
13
+ "addAttribute",
14
+ "spreadAttributes",
15
+ "defineStyleVars",
16
+ "defineScriptVars",
17
+ "Fragment",
18
+ "unescapeHTML",
19
+ "maybeRenderHead",
20
+ "renderHead",
21
+ "slots",
22
+ "props",
23
+ "children"
24
+ ]);
25
+ function BackgroundHlsVideoPlayer(props) {
26
+ const { poster, src, className, ...rawRestProps } = props;
27
+ const restProps = {};
28
+ for (const [k, v] of Object.entries(rawRestProps)) {
29
+ if (FORBIDDEN_PROPS.has(k))
30
+ continue;
31
+ if (k.startsWith("_"))
32
+ continue;
33
+ if (typeof v === "function")
34
+ continue;
35
+ restProps[k] = v;
36
+ }
37
+ const videoRef = useRef(null);
38
+ useEffect(() => {
39
+ if (!videoRef.current || !src)
40
+ return;
41
+ const video = videoRef.current;
42
+ if (!Hls.isSupported()) {
43
+ if (video.canPlayType("application/vnd.apple.mpegurl")) {
44
+ video.src = src;
45
+ video.play().catch(() => {
46
+ });
47
+ }
48
+ return;
49
+ }
50
+ const hls = new Hls({
51
+ enableWorker: true
52
+ });
53
+ hls.on(Hls.Events.MANIFEST_PARSED, () => {
54
+ video.play().catch(() => {
55
+ });
56
+ });
57
+ hls.on(Hls.Events.ERROR, (event, data) => {
58
+ if (data.fatal) {
59
+ switch (data.type) {
60
+ case Hls.ErrorTypes.NETWORK_ERROR:
61
+ hls.startLoad();
62
+ break;
63
+ case Hls.ErrorTypes.MEDIA_ERROR:
64
+ hls.recoverMediaError();
65
+ break;
66
+ default:
67
+ hls.destroy();
68
+ break;
69
+ }
70
+ }
71
+ });
72
+ hls.loadSource(src);
73
+ hls.attachMedia(video);
74
+ return () => {
75
+ hls.destroy();
76
+ };
77
+ }, [src]);
78
+ return /* @__PURE__ */ jsxRuntimeExports.jsx(
79
+ "video",
80
+ {
81
+ ref: videoRef,
82
+ autoPlay: true,
83
+ loop: true,
84
+ muted: true,
85
+ playsInline: true,
86
+ poster,
87
+ className,
88
+ preload: "metadata",
89
+ ...restProps
90
+ }
91
+ );
92
+ }
93
+ function VideoPlayIcon(props) {
94
+ const { classNames } = props;
95
+ return /* @__PURE__ */ jsxRuntimeExports.jsx(
96
+ "div",
97
+ {
98
+ className: clsx(
99
+ "flex items-center justify-center w-14 h-14 lg:w-[130px] lg:h-[130px] bg-white/15 rounded-full backdrop-blur-sm hover:shadow-md transition-all duration-300 hover:scale-110 group",
100
+ classNames == null ? void 0 : classNames.playButtonOuter
101
+ ),
102
+ children: /* @__PURE__ */ jsxRuntimeExports.jsx(
103
+ "div",
104
+ {
105
+ className: clsx(
106
+ "w-10 h-10 lg:w-[90px] lg:h-[90px] bg-white relative overflow-hidden rounded-full",
107
+ classNames == null ? void 0 : classNames.playButtonInner
108
+ ),
109
+ children: /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: "absolute inset-0 cross-gradient box-shadow-1", children: /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: "w-full h-full flex items-center justify-center", children: /* @__PURE__ */ jsxRuntimeExports.jsx(
110
+ "svg",
111
+ {
112
+ className: clsx(
113
+ "size-4 lg:size-8 text-gray-700",
114
+ classNames == null ? void 0 : classNames.playIcon
115
+ ),
116
+ viewBox: "0 0 30 32",
117
+ fill: "currentColor",
118
+ xmlns: "http://www.w3.org/2000/svg",
119
+ children: /* @__PURE__ */ jsxRuntimeExports.jsx("path", { d: "M27.2003 19.4972C29.945 17.9735 29.945 14.0264 27.2003 12.5027L6.44148 0.978573C3.77538 -0.501503 0.5 1.42643 0.5 4.47581V27.5241C0.5 30.5735 3.77537 32.5014 6.44147 31.0214L27.2003 19.4972Z" })
120
+ }
121
+ ) }) })
122
+ }
123
+ )
124
+ }
125
+ );
126
+ }
127
+ const ReactVideoPlayer = forwardRef((props, ref) => {
128
+ var _a, _b, _c, _d;
129
+ const {
130
+ endTitle,
131
+ media,
132
+ onToggleSelect,
133
+ posterUrl,
134
+ eagerLoad,
135
+ classNames,
136
+ callToAction,
137
+ designMode,
138
+ children,
139
+ ...rest
140
+ } = props;
141
+ const videoRef = useRef(null);
142
+ const hlsRef = useRef(null);
143
+ const [isPlaying, setIsPlaying] = useState(false);
144
+ const [isEnded, setIsEnded] = useState(false);
145
+ const [isSourceReady, setIsSourceReady] = useState(false);
146
+ const sourceReadyRef = useRef(false);
147
+ const [isLoading, setIsLoading] = useState(false);
148
+ const isEndedRef = useRef(false);
149
+ const [hasStarted, setHasStarted] = useState(false);
150
+ const ensureSourceReady = useCallback(() => {
151
+ var _a2;
152
+ const video = videoRef.current;
153
+ const url = (_a2 = media == null ? void 0 : media.file) == null ? void 0 : _a2.original;
154
+ if (!video || !url)
155
+ return false;
156
+ if (sourceReadyRef.current)
157
+ return true;
158
+ if ((media == null ? void 0 : media.storageType) === "cloudflare_stream") {
159
+ if (!Hls.isSupported()) {
160
+ if (video.canPlayType("application/vnd.apple.mpegurl")) {
161
+ video.src = url;
162
+ sourceReadyRef.current = true;
163
+ setIsSourceReady(true);
164
+ return true;
165
+ }
166
+ return false;
167
+ }
168
+ const hls = new Hls({ enableWorker: true });
169
+ hls.on(Hls.Events.ERROR, (_event, data) => {
170
+ if (data.fatal) {
171
+ switch (data.type) {
172
+ case Hls.ErrorTypes.NETWORK_ERROR:
173
+ hls.startLoad();
174
+ break;
175
+ case Hls.ErrorTypes.MEDIA_ERROR:
176
+ hls.recoverMediaError();
177
+ break;
178
+ default:
179
+ hls.destroy();
180
+ break;
181
+ }
182
+ }
183
+ });
184
+ hls.loadSource(url);
185
+ hls.attachMedia(video);
186
+ hlsRef.current = hls;
187
+ sourceReadyRef.current = true;
188
+ setIsSourceReady(true);
189
+ return true;
190
+ }
191
+ video.src = url;
192
+ sourceReadyRef.current = true;
193
+ setIsSourceReady(true);
194
+ return true;
195
+ }, [(_a = media == null ? void 0 : media.file) == null ? void 0 : _a.original, media == null ? void 0 : media.storageType]);
196
+ const handleContainerClick = useCallback(
197
+ (e) => {
198
+ if (designMode)
199
+ return;
200
+ if (isPlaying && videoRef.current) {
201
+ e.stopPropagation();
202
+ videoRef.current.pause();
203
+ return;
204
+ }
205
+ if ((media == null ? void 0 : media.id) != null) {
206
+ onToggleSelect == null ? void 0 : onToggleSelect(media.id);
207
+ }
208
+ },
209
+ [isPlaying, media == null ? void 0 : media.id, onToggleSelect, designMode]
210
+ );
211
+ const handlePlayClick = useCallback(
212
+ (e) => {
213
+ if (designMode)
214
+ return;
215
+ e.stopPropagation();
216
+ const v = videoRef.current;
217
+ if (!v)
218
+ return;
219
+ if (isPlaying) {
220
+ v.pause();
221
+ return;
222
+ }
223
+ const ok = ensureSourceReady();
224
+ if (!ok)
225
+ return;
226
+ setIsLoading(true);
227
+ v.play().catch((error) => {
228
+ console.log("ReactVideoPlayer play() failed:", error);
229
+ setIsLoading(false);
230
+ });
231
+ },
232
+ [isPlaying, designMode, ensureSourceReady]
233
+ );
234
+ useEffect(() => {
235
+ const video = videoRef.current;
236
+ if (!video)
237
+ return;
238
+ video.pause();
239
+ if (hlsRef.current) {
240
+ hlsRef.current.destroy();
241
+ hlsRef.current = null;
242
+ }
243
+ video.removeAttribute("src");
244
+ video.load();
245
+ setIsSourceReady(false);
246
+ sourceReadyRef.current = false;
247
+ const onPlay = () => {
248
+ setIsPlaying(true);
249
+ setIsEnded(false);
250
+ isEndedRef.current = false;
251
+ setIsLoading(false);
252
+ setHasStarted(true);
253
+ };
254
+ const onPause = () => setIsPlaying(false);
255
+ const onEnded = () => {
256
+ setIsPlaying(false);
257
+ setIsEnded(true);
258
+ isEndedRef.current = true;
259
+ setIsLoading(false);
260
+ };
261
+ const onWaiting = () => {
262
+ if (!isEndedRef.current)
263
+ setIsLoading(true);
264
+ };
265
+ const onCanPlay = () => {
266
+ setIsLoading(false);
267
+ };
268
+ video.addEventListener("play", onPlay);
269
+ video.addEventListener("pause", onPause);
270
+ video.addEventListener("ended", onEnded);
271
+ video.addEventListener("waiting", onWaiting);
272
+ video.addEventListener("canplay", onCanPlay);
273
+ video.addEventListener("playing", onCanPlay);
274
+ if (eagerLoad) {
275
+ ensureSourceReady();
276
+ }
277
+ return () => {
278
+ video.removeEventListener("play", onPlay);
279
+ video.removeEventListener("pause", onPause);
280
+ video.removeEventListener("ended", onEnded);
281
+ video.removeEventListener("waiting", onWaiting);
282
+ video.removeEventListener("canplay", onCanPlay);
283
+ video.removeEventListener("playing", onCanPlay);
284
+ if (hlsRef.current) {
285
+ hlsRef.current.destroy();
286
+ hlsRef.current = null;
287
+ }
288
+ };
289
+ }, [eagerLoad, ensureSourceReady, (_b = media == null ? void 0 : media.file) == null ? void 0 : _b.original, media == null ? void 0 : media.storageType]);
290
+ return /* @__PURE__ */ jsxRuntimeExports.jsxs(
291
+ "div",
292
+ {
293
+ ref,
294
+ className: clsx$1(
295
+ "relative w-full rounded-2xl",
296
+ (classNames == null ? void 0 : classNames.aspect) ?? "aspect-video",
297
+ classNames == null ? void 0 : classNames.container
298
+ ),
299
+ onClick: handleContainerClick,
300
+ ...rest,
301
+ children: [
302
+ /* @__PURE__ */ jsxRuntimeExports.jsxs(
303
+ "video",
304
+ {
305
+ ref: videoRef,
306
+ onClick: (e) => !designMode && e.stopPropagation(),
307
+ preload: eagerLoad ? "metadata" : "none",
308
+ poster: posterUrl ?? ((_c = media == null ? void 0 : media.file) == null ? void 0 : _c.thumbnail),
309
+ className: clsx$1(
310
+ "w-full h-full rounded-lg object-cover",
311
+ classNames == null ? void 0 : classNames.video
312
+ ),
313
+ playsInline: true,
314
+ controls: !designMode && hasStarted,
315
+ disablePictureInPicture: true,
316
+ controlsList: "nodownload noremoteplayback noplaybackrate",
317
+ children: [
318
+ !(media == null ? void 0 : media.storageType) && ((_d = media == null ? void 0 : media.file) == null ? void 0 : _d.original) && (eagerLoad || isSourceReady) ? /* @__PURE__ */ jsxRuntimeExports.jsx("source", { src: media.file.original }) : null,
319
+ "Your browser does not support video playback."
320
+ ]
321
+ }
322
+ ),
323
+ !isPlaying && !isEnded && !isLoading && /* @__PURE__ */ jsxRuntimeExports.jsx(
324
+ "button",
325
+ {
326
+ type: "button",
327
+ onClick: handlePlayClick,
328
+ className: clsx$1(
329
+ "absolute inset-0 items-center justify-center w-full h-full transition rounded-lg z-10",
330
+ hasStarted ? "hidden md:flex" : "flex",
331
+ classNames == null ? void 0 : classNames.playButton
332
+ ),
333
+ children: children || /* @__PURE__ */ jsxRuntimeExports.jsx(VideoPlayIcon, { classNames })
334
+ }
335
+ ),
336
+ !isPlaying && !isEnded && isLoading && /* @__PURE__ */ jsxRuntimeExports.jsx(
337
+ "div",
338
+ {
339
+ className: clsx$1(
340
+ "absolute inset-0 flex items-center justify-center w-full h-full rounded-lg z-10 bg-black/20",
341
+ classNames == null ? void 0 : classNames.loadingOverlay
342
+ ),
343
+ onClick: (e) => e.stopPropagation(),
344
+ children: /* @__PURE__ */ jsxRuntimeExports.jsxs(
345
+ "div",
346
+ {
347
+ className: clsx$1(
348
+ "flex items-center gap-3 rounded-full bg-black/50 px-4 py-2 text-white",
349
+ classNames == null ? void 0 : classNames.loadingContent
350
+ ),
351
+ children: [
352
+ /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: "h-4 w-4 animate-spin rounded-full border-2 border-white/30 border-t-white" }),
353
+ /* @__PURE__ */ jsxRuntimeExports.jsx("span", { className: "text-sm", children: "Loading..." })
354
+ ]
355
+ }
356
+ )
357
+ }
358
+ ),
359
+ /* @__PURE__ */ jsxRuntimeExports.jsxs(
360
+ "div",
361
+ {
362
+ className: clsx$1(
363
+ "absolute inset-0 bg-black/50 flex-col gap-6 items-center justify-center text-center text-white hidden z-10 rounded-2xl",
364
+ classNames == null ? void 0 : classNames.overlay
365
+ ),
366
+ style: { display: isEnded ? "flex" : "none" },
367
+ children: [
368
+ /* @__PURE__ */ jsxRuntimeExports.jsx(
369
+ "p",
370
+ {
371
+ className: clsx$1("text-4xl drop-shadow-lg", classNames == null ? void 0 : classNames.overlayTitle),
372
+ children: endTitle ?? "Contact Us Now"
373
+ }
374
+ ),
375
+ /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: "flex items-center gap-4", children: [
376
+ /* @__PURE__ */ jsxRuntimeExports.jsx(
377
+ ReactModalTrigger,
378
+ {
379
+ className: clsx$1(
380
+ "btn btn-primary px-10 py-2.5 rounded-full ripple",
381
+ classNames == null ? void 0 : classNames.ctaButton
382
+ ),
383
+ callToAction,
384
+ children: "Consult Now"
385
+ }
386
+ ),
387
+ /* @__PURE__ */ jsxRuntimeExports.jsx(
388
+ "button",
389
+ {
390
+ type: "button",
391
+ className: clsx$1(
392
+ "px-10 py-2.5 bg-white/20 hover:bg-white/30 rounded-full transition text-sm",
393
+ classNames == null ? void 0 : classNames.overlayReplayButton
394
+ ),
395
+ onClick: (e) => {
396
+ e.stopPropagation();
397
+ const v = videoRef.current;
398
+ if (!v)
399
+ return;
400
+ const ok = ensureSourceReady();
401
+ if (!ok)
402
+ return;
403
+ setIsLoading(true);
404
+ v.currentTime = 0;
405
+ setIsEnded(false);
406
+ v.play().catch((error) => {
407
+ console.log("ReactVideoPlayer play() failed:", error);
408
+ setIsLoading(false);
409
+ });
410
+ },
411
+ children: "Replay"
412
+ }
413
+ )
414
+ ] })
415
+ ]
416
+ }
417
+ )
418
+ ]
419
+ }
420
+ );
421
+ });
422
+ export {
423
+ BackgroundHlsVideoPlayer,
424
+ ReactVideoPlayer
425
+ };
426
+ //# sourceMappingURL=video.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"video.mjs","sources":["../src/components/BackgroundHlsVideoPlayer.tsx","../src/components/VideoPlayIcon.tsx","../src/components/ReactVideoPlayer.tsx"],"sourcesContent":["import { useEffect, useRef, type VideoHTMLAttributes } from \"react\";\nimport Hls from \"hls.js\";\n\n// 需要过滤掉的非 video 属性(Astro runtime 透传的方法/对象)\nconst FORBIDDEN_PROPS = new Set([\n 'createMetadata',\n 'createComponent',\n 'createAstro',\n 'renderComponent',\n 'renderSlot',\n 'render',\n 'addAttribute',\n 'spreadAttributes',\n 'defineStyleVars',\n 'defineScriptVars',\n 'Fragment',\n 'unescapeHTML',\n 'maybeRenderHead',\n 'renderHead',\n 'slots',\n 'props',\n 'children',\n]);\n\nexport function BackgroundHlsVideoPlayer(\n props: VideoHTMLAttributes<HTMLVideoElement>\n) {\n const { poster, src, className, ...rawRestProps } = props;\n // 过滤掉 Astro runtime 透传的非 video 属性\n const restProps: Record<string, unknown> = {};\n for (const [k, v] of Object.entries(rawRestProps)) {\n if (FORBIDDEN_PROPS.has(k)) continue;\n if (k.startsWith('_')) continue;\n if (typeof v === 'function') continue;\n restProps[k] = v;\n }\n const videoRef = useRef<HTMLVideoElement>(null);\n\n useEffect(() => {\n if (!videoRef.current || !src) return;\n\n const video = videoRef.current;\n\n if (!Hls.isSupported()) {\n if (video.canPlayType(\"application/vnd.apple.mpegurl\")) {\n video.src = src;\n video.play().catch(() => {});\n }\n return;\n }\n\n const hls = new Hls({\n enableWorker: true,\n });\n\n hls.on(Hls.Events.MANIFEST_PARSED, () => {\n video.play().catch(() => {});\n });\n\n hls.on(Hls.Events.ERROR, (event, data) => {\n if (data.fatal) {\n switch (data.type) {\n case Hls.ErrorTypes.NETWORK_ERROR:\n hls.startLoad();\n break;\n case Hls.ErrorTypes.MEDIA_ERROR:\n hls.recoverMediaError();\n break;\n default:\n hls.destroy();\n break;\n }\n }\n });\n\n hls.loadSource(src);\n hls.attachMedia(video);\n\n return () => {\n hls.destroy();\n };\n }, [src]);\n\n return (\n <video\n ref={videoRef}\n autoPlay\n loop\n muted\n playsInline\n poster={poster}\n className={className}\n preload=\"metadata\"\n {...restProps}\n ></video>\n );\n}\n","import { clsx } from \"clsx\";\n\nexport function VideoPlayIcon(props: {\n classNames?: {\n playButton?: string;\n playButtonOuter?: string;\n playButtonInner?: string;\n playIcon?: string;\n };\n}) {\n const { classNames } = props;\n return (\n <div\n className={clsx(\n \"flex items-center justify-center w-14 h-14 lg:w-[130px] lg:h-[130px] bg-white/15 rounded-full backdrop-blur-sm hover:shadow-md transition-all duration-300 hover:scale-110 group\",\n classNames?.playButtonOuter,\n )}\n >\n <div\n className={clsx(\n \"w-10 h-10 lg:w-[90px] lg:h-[90px] bg-white relative overflow-hidden rounded-full\",\n classNames?.playButtonInner,\n )}\n >\n <div className=\"absolute inset-0 cross-gradient box-shadow-1\">\n <div className=\"w-full h-full flex items-center justify-center\">\n <svg\n className={clsx(\n \"size-4 lg:size-8 text-gray-700\",\n classNames?.playIcon,\n )}\n viewBox=\"0 0 30 32\"\n fill=\"currentColor\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path d=\"M27.2003 19.4972C29.945 17.9735 29.945 14.0264 27.2003 12.5027L6.44148 0.978573C3.77538 -0.501503 0.5 1.42643 0.5 4.47581V27.5241C0.5 30.5735 3.77537 32.5014 6.44147 31.0214L27.2003 19.4972Z\" />\n </svg>\n </div>\n </div>\n </div>\n </div>\n );\n}\n","import React, {\n useCallback,\n useEffect,\n useRef,\n useState,\n forwardRef,\n} from \"react\";\nimport Hls from \"hls.js\";\nimport type { Media } from \"@rxdrag/rxcms-models\";\nimport { ReactModalTrigger } from \"./ReactModalTrigger\";\nimport clsx from \"clsx\";\nimport { VideoPlayIcon } from \"./VideoPlayIcon\";\n\nexport type ID = string | number;\n\nexport type VideoPlayerClassNames = {\n container?: string;\n aspect?: string;\n video?: string;\n playButton?: string;\n playButtonOuter?: string;\n playButtonInner?: string;\n playIcon?: string;\n loadingOverlay?: string;\n loadingContent?: string;\n overlay?: string;\n overlayTitle?: string;\n ctaButton?: string;\n overlayReplayButton?: string;\n};\n\nexport const ReactVideoPlayer = forwardRef<\n HTMLDivElement,\n {\n endTitle?: string;\n media?: Media;\n posterUrl?: string;\n eagerLoad?: boolean;\n classNames?: VideoPlayerClassNames;\n callToAction?: string;\n onToggleSelect?: (id: ID) => void;\n designMode?: boolean;\n children?: React.ReactNode;\n \n }\n>((props, ref) => {\n const {\n endTitle,\n media,\n onToggleSelect,\n posterUrl,\n eagerLoad,\n classNames,\n callToAction,\n designMode,\n children,\n ...rest\n } = props;\n const videoRef = useRef<HTMLVideoElement>(null);\n const hlsRef = useRef<Hls | null>(null);\n const [isPlaying, setIsPlaying] = useState(false);\n const [isEnded, setIsEnded] = useState(false);\n const [isSourceReady, setIsSourceReady] = useState(false);\n const sourceReadyRef = useRef(false);\n const [isLoading, setIsLoading] = useState(false);\n const isEndedRef = useRef(false);\n const [hasStarted, setHasStarted] = useState(false);\n\n const ensureSourceReady = useCallback(() => {\n const video = videoRef.current;\n const url = media?.file?.original;\n if (!video || !url) return false;\n if (sourceReadyRef.current) return true;\n\n if (media?.storageType === \"cloudflare_stream\") {\n if (!Hls.isSupported()) {\n if (video.canPlayType(\"application/vnd.apple.mpegurl\")) {\n video.src = url;\n sourceReadyRef.current = true;\n setIsSourceReady(true);\n return true;\n }\n return false;\n }\n\n const hls = new Hls({ enableWorker: true });\n hls.on(Hls.Events.ERROR, (_event, data) => {\n if (data.fatal) {\n switch (data.type) {\n case Hls.ErrorTypes.NETWORK_ERROR:\n hls.startLoad();\n break;\n case Hls.ErrorTypes.MEDIA_ERROR:\n hls.recoverMediaError();\n break;\n default:\n hls.destroy();\n break;\n }\n }\n });\n hls.loadSource(url);\n hls.attachMedia(video);\n hlsRef.current = hls;\n sourceReadyRef.current = true;\n setIsSourceReady(true);\n return true;\n }\n\n video.src = url;\n sourceReadyRef.current = true;\n setIsSourceReady(true);\n return true;\n }, [media?.file?.original, media?.storageType]);\n\n const handleContainerClick = useCallback(\n (e: React.MouseEvent) => {\n if (designMode) return;\n if (isPlaying && videoRef.current) {\n e.stopPropagation();\n videoRef.current.pause();\n return;\n }\n if (media?.id != null) {\n onToggleSelect?.(media.id);\n }\n },\n [isPlaying, media?.id, onToggleSelect, designMode],\n );\n\n const handlePlayClick = useCallback(\n (e: React.MouseEvent) => {\n if (designMode) return;\n e.stopPropagation();\n const v = videoRef.current;\n if (!v) return;\n if (isPlaying) {\n v.pause();\n return;\n }\n\n const ok = ensureSourceReady();\n if (!ok) return;\n\n setIsLoading(true);\n\n v.play().catch((error) => {\n console.log(\"ReactVideoPlayer play() failed:\", error);\n setIsLoading(false);\n });\n },\n [isPlaying, designMode, ensureSourceReady],\n );\n\n useEffect(() => {\n const video = videoRef.current;\n if (!video) return;\n\n video.pause();\n if (hlsRef.current) {\n hlsRef.current.destroy();\n hlsRef.current = null;\n }\n video.removeAttribute(\"src\");\n video.load();\n setIsSourceReady(false);\n sourceReadyRef.current = false;\n\n const onPlay = () => {\n setIsPlaying(true);\n setIsEnded(false);\n isEndedRef.current = false;\n setIsLoading(false);\n setHasStarted(true);\n };\n const onPause = () => setIsPlaying(false);\n const onEnded = () => {\n setIsPlaying(false);\n setIsEnded(true);\n isEndedRef.current = true;\n setIsLoading(false);\n };\n const onWaiting = () => {\n if (!isEndedRef.current) setIsLoading(true);\n };\n const onCanPlay = () => {\n setIsLoading(false);\n };\n\n video.addEventListener(\"play\", onPlay);\n video.addEventListener(\"pause\", onPause);\n video.addEventListener(\"ended\", onEnded);\n video.addEventListener(\"waiting\", onWaiting);\n video.addEventListener(\"canplay\", onCanPlay);\n video.addEventListener(\"playing\", onCanPlay);\n\n if (eagerLoad) {\n ensureSourceReady();\n }\n\n return () => {\n video.removeEventListener(\"play\", onPlay);\n video.removeEventListener(\"pause\", onPause);\n video.removeEventListener(\"ended\", onEnded);\n video.removeEventListener(\"waiting\", onWaiting);\n video.removeEventListener(\"canplay\", onCanPlay);\n video.removeEventListener(\"playing\", onCanPlay);\n\n if (hlsRef.current) {\n hlsRef.current.destroy();\n hlsRef.current = null;\n }\n };\n }, [eagerLoad, ensureSourceReady, media?.file?.original, media?.storageType]);\n\n return (\n <div\n ref={ref}\n className={clsx(\n \"relative w-full rounded-2xl\",\n classNames?.aspect ?? \"aspect-video\",\n classNames?.container,\n )}\n onClick={handleContainerClick}\n {...rest}\n >\n <video\n ref={videoRef}\n onClick={(e) => !designMode && e.stopPropagation()}\n preload={eagerLoad ? \"metadata\" : \"none\"}\n poster={posterUrl ?? media?.file?.thumbnail}\n className={clsx(\n \"w-full h-full rounded-lg object-cover\",\n classNames?.video,\n )}\n playsInline\n controls={!designMode && hasStarted}\n disablePictureInPicture\n controlsList=\"nodownload noremoteplayback noplaybackrate\"\n >\n {!media?.storageType &&\n media?.file?.original &&\n (eagerLoad || isSourceReady) ? (\n <source src={media.file.original} />\n ) : null}\n Your browser does not support video playback.\n </video>\n\n {!isPlaying && !isEnded && !isLoading && (\n <button\n type=\"button\"\n onClick={handlePlayClick}\n className={clsx(\n \"absolute inset-0 items-center justify-center w-full h-full transition rounded-lg z-10\",\n hasStarted ? \"hidden md:flex\" : \"flex\",\n classNames?.playButton,\n )}\n >\n {children || <VideoPlayIcon classNames={classNames} />}\n </button>\n )}\n\n {!isPlaying && !isEnded && isLoading && (\n <div\n className={clsx(\n \"absolute inset-0 flex items-center justify-center w-full h-full rounded-lg z-10 bg-black/20\",\n classNames?.loadingOverlay,\n )}\n onClick={(e) => e.stopPropagation()}\n >\n <div\n className={clsx(\n \"flex items-center gap-3 rounded-full bg-black/50 px-4 py-2 text-white\",\n classNames?.loadingContent,\n )}\n >\n <div className=\"h-4 w-4 animate-spin rounded-full border-2 border-white/30 border-t-white\" />\n <span className=\"text-sm\">Loading...</span>\n </div>\n </div>\n )}\n\n <div\n className={clsx(\n \"absolute inset-0 bg-black/50 flex-col gap-6 items-center justify-center text-center text-white hidden z-10 rounded-2xl\",\n classNames?.overlay,\n )}\n style={{ display: isEnded ? \"flex\" : \"none\" }}\n >\n <p\n className={clsx(\"text-4xl drop-shadow-lg\", classNames?.overlayTitle)}\n >\n {endTitle ?? \"Contact Us Now\"}\n </p>\n <div className=\"flex items-center gap-4\">\n <ReactModalTrigger\n className={clsx(\n \"btn btn-primary px-10 py-2.5 rounded-full ripple\",\n classNames?.ctaButton,\n )}\n callToAction={callToAction}\n >\n Consult Now\n </ReactModalTrigger>\n <button\n type=\"button\"\n className={clsx(\n \"px-10 py-2.5 bg-white/20 hover:bg-white/30 rounded-full transition text-sm\",\n classNames?.overlayReplayButton,\n )}\n onClick={(e) => {\n e.stopPropagation();\n const v = videoRef.current;\n if (!v) return;\n const ok = ensureSourceReady();\n if (!ok) return;\n setIsLoading(true);\n v.currentTime = 0;\n setIsEnded(false);\n v.play().catch((error) => {\n console.log(\"ReactVideoPlayer play() failed:\", error);\n setIsLoading(false);\n });\n }}\n >\n Replay\n </button>\n </div>\n </div>\n </div>\n );\n});\n"],"names":["jsx","_a","jsxs","clsx"],"mappings":"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"}
package/forms.ts ADDED
@@ -0,0 +1 @@
1
+ export * from "./src/forms";
package/index.ts ADDED
@@ -0,0 +1 @@
1
+ export * from "./src";
package/media.ts ADDED
@@ -0,0 +1 @@
1
+ export * from "./src/media";