@getontime/cli 4.2.0 → 4.2.1

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 (393) hide show
  1. package/client/assets/Backstage-WSlbFC9X.js +2 -0
  2. package/client/assets/Backstage-WSlbFC9X.js.br +0 -0
  3. package/client/assets/Backstage-WSlbFC9X.js.gz +0 -0
  4. package/client/assets/{Backstage-DG-hwPI3.js.map → Backstage-WSlbFC9X.js.map} +1 -1
  5. package/client/assets/{Countdown-C8LGl1pp.js → Countdown-B32qlxYT.js} +2 -2
  6. package/client/assets/Countdown-B32qlxYT.js.br +0 -0
  7. package/client/assets/Countdown-B32qlxYT.js.gz +0 -0
  8. package/client/assets/{Countdown-C8LGl1pp.js.map → Countdown-B32qlxYT.js.map} +1 -1
  9. package/client/assets/{CustomTranslationModal-CJ9-aDjl.js → CustomTranslationModal-CtBvokyt.js} +2 -2
  10. package/client/assets/CustomTranslationModal-CtBvokyt.js.br +0 -0
  11. package/client/assets/CustomTranslationModal-CtBvokyt.js.gz +0 -0
  12. package/client/assets/{CustomTranslationModal-CJ9-aDjl.js.map → CustomTranslationModal-CtBvokyt.js.map} +1 -1
  13. package/client/assets/DelayIndicator-BFZFpsY5.js +2 -0
  14. package/client/assets/DelayIndicator-BFZFpsY5.js.br +0 -0
  15. package/client/assets/DelayIndicator-BFZFpsY5.js.gz +0 -0
  16. package/client/assets/{DelayIndicator-F4GdgsGh.js.map → DelayIndicator-BFZFpsY5.js.map} +1 -1
  17. package/client/assets/EditorFeatureWrapper-DaMxgBMP.js +2 -0
  18. package/client/assets/EditorFeatureWrapper-DaMxgBMP.js.br +0 -0
  19. package/client/assets/EditorFeatureWrapper-DaMxgBMP.js.gz +0 -0
  20. package/client/assets/{EditorFeatureWrapper-eIpSr_UK.js.map → EditorFeatureWrapper-DaMxgBMP.js.map} +1 -1
  21. package/client/assets/EditorUtils-DoaSwWiz.js +2 -0
  22. package/client/assets/EditorUtils-DoaSwWiz.js.br +0 -0
  23. package/client/assets/EditorUtils-DoaSwWiz.js.gz +0 -0
  24. package/client/assets/{EditorUtils-Bd3J5Dvf.js.map → EditorUtils-DoaSwWiz.js.map} +1 -1
  25. package/client/assets/Empty-D1UteOYj.js +2 -0
  26. package/client/assets/Empty-D1UteOYj.js.br +0 -0
  27. package/client/assets/Empty-D1UteOYj.js.gz +0 -0
  28. package/client/assets/{Empty-C0IdV_kI.js.map → Empty-D1UteOYj.js.map} +1 -1
  29. package/client/assets/EmptyPage-DeRjpRKZ.js +2 -0
  30. package/client/assets/EmptyPage-DeRjpRKZ.js.br +0 -0
  31. package/client/assets/EmptyPage-DeRjpRKZ.js.gz +0 -0
  32. package/client/assets/{EmptyPage-Ct3d0DqJ.js.map → EmptyPage-DeRjpRKZ.js.map} +1 -1
  33. package/client/assets/FollowButton-FodezDem.js +2 -0
  34. package/client/assets/FollowButton-FodezDem.js.br +0 -0
  35. package/client/assets/FollowButton-FodezDem.js.gz +0 -0
  36. package/client/assets/{FollowButton-BG-ycRWu.js.map → FollowButton-FodezDem.js.map} +1 -1
  37. package/client/assets/{MessageControlExport-X-4dl9QT.js → MessageControlExport-CFGgiwk_.js} +3 -3
  38. package/client/assets/MessageControlExport-CFGgiwk_.js.br +0 -0
  39. package/client/assets/MessageControlExport-CFGgiwk_.js.gz +0 -0
  40. package/client/assets/MessageControlExport-CFGgiwk_.js.map +1 -0
  41. package/client/assets/{MilestoneEditor-rgBQSXVU.js → MilestoneEditor-B5BdJ5ju.js} +2 -2
  42. package/client/assets/MilestoneEditor-B5BdJ5ju.js.br +0 -0
  43. package/client/assets/MilestoneEditor-B5BdJ5ju.js.gz +0 -0
  44. package/client/assets/{MilestoneEditor-rgBQSXVU.js.map → MilestoneEditor-B5BdJ5ju.js.map} +1 -1
  45. package/client/assets/Modal-B8ZZbVMg.js +2 -0
  46. package/client/assets/Modal-B8ZZbVMg.js.br +0 -0
  47. package/client/assets/Modal-B8ZZbVMg.js.gz +0 -0
  48. package/client/assets/{Modal-Bn1bZkwb.js.map → Modal-B8ZZbVMg.js.map} +1 -1
  49. package/client/assets/{MultiPartProgressBar-Cmw-gisu.js → MultiPartProgressBar-BKHk19Hb.js} +2 -2
  50. package/client/assets/MultiPartProgressBar-BKHk19Hb.js.br +0 -0
  51. package/client/assets/MultiPartProgressBar-BKHk19Hb.js.gz +0 -0
  52. package/client/assets/{MultiPartProgressBar-Cmw-gisu.js.map → MultiPartProgressBar-BKHk19Hb.js.map} +1 -1
  53. package/client/assets/{OperatorExport-CJd8jmY4.js → OperatorExport-DQM14DsN.js} +2 -2
  54. package/client/assets/OperatorExport-DQM14DsN.js.br +0 -0
  55. package/client/assets/OperatorExport-DQM14DsN.js.gz +0 -0
  56. package/client/assets/{OperatorExport-CJd8jmY4.js.map → OperatorExport-DQM14DsN.js.map} +1 -1
  57. package/client/assets/{OverviewWrapper-1Vj3_ojX.js → OverviewWrapper-D1hUkrRi.js} +2 -2
  58. package/client/assets/OverviewWrapper-D1hUkrRi.js.br +0 -0
  59. package/client/assets/OverviewWrapper-D1hUkrRi.js.gz +0 -0
  60. package/client/assets/{OverviewWrapper-1Vj3_ojX.js.map → OverviewWrapper-D1hUkrRi.js.map} +1 -1
  61. package/client/assets/PipHost-B9-cZ8Lm.js +2 -0
  62. package/client/assets/PipHost-B9-cZ8Lm.js.br +0 -0
  63. package/client/assets/PipHost-B9-cZ8Lm.js.gz +0 -0
  64. package/client/assets/PipHost-B9-cZ8Lm.js.map +1 -0
  65. package/client/assets/PipHost-DEhjTbGT.css +1 -0
  66. package/client/assets/PipHost-DEhjTbGT.css.br +0 -0
  67. package/client/assets/PipHost-DEhjTbGT.css.gz +0 -0
  68. package/client/assets/{ProjectInfo-BduQgjcz.js → ProjectInfo-Dp1TZyBd.js} +2 -2
  69. package/client/assets/ProjectInfo-Dp1TZyBd.js.br +0 -0
  70. package/client/assets/ProjectInfo-Dp1TZyBd.js.gz +0 -0
  71. package/client/assets/{ProjectInfo-BduQgjcz.js.map → ProjectInfo-Dp1TZyBd.js.map} +1 -1
  72. package/client/assets/ProtectRoute-EejQ5o_H.js +2 -0
  73. package/client/assets/ProtectRoute-EejQ5o_H.js.br +0 -0
  74. package/client/assets/ProtectRoute-EejQ5o_H.js.gz +0 -0
  75. package/client/assets/{ProtectRoute-Ci_AIozP.js.map → ProtectRoute-EejQ5o_H.js.map} +1 -1
  76. package/client/assets/{ProtectedCuesheet-D_zdkwM-.js → ProtectedCuesheet-DvYSgueA.js} +2 -2
  77. package/client/assets/ProtectedCuesheet-DvYSgueA.js.br +0 -0
  78. package/client/assets/ProtectedCuesheet-DvYSgueA.js.gz +0 -0
  79. package/client/assets/{ProtectedCuesheet-D_zdkwM-.js.map → ProtectedCuesheet-DvYSgueA.js.map} +1 -1
  80. package/client/assets/{ProtectedEditor-CNL2ig79.js → ProtectedEditor-B0l0X3QP.js} +3 -3
  81. package/client/assets/ProtectedEditor-B0l0X3QP.js.br +0 -0
  82. package/client/assets/ProtectedEditor-B0l0X3QP.js.gz +0 -0
  83. package/client/assets/ProtectedEditor-B0l0X3QP.js.map +1 -0
  84. package/client/assets/RundownEntry-CwiStTnR.js +2 -0
  85. package/client/assets/RundownEntry-CwiStTnR.js.br +0 -0
  86. package/client/assets/RundownEntry-CwiStTnR.js.gz +0 -0
  87. package/client/assets/RundownEntry-CwiStTnR.js.map +1 -0
  88. package/client/assets/RundownExport-CCaOfHIr.js +3 -0
  89. package/client/assets/RundownExport-CCaOfHIr.js.br +0 -0
  90. package/client/assets/RundownExport-CCaOfHIr.js.gz +0 -0
  91. package/client/assets/RundownExport-CCaOfHIr.js.map +1 -0
  92. package/client/assets/Select-cHK8JrMG.js +2 -0
  93. package/client/assets/Select-cHK8JrMG.js.br +0 -0
  94. package/client/assets/Select-cHK8JrMG.js.gz +0 -0
  95. package/client/assets/{Select-B5xNi_tM.js.map → Select-cHK8JrMG.js.map} +1 -1
  96. package/client/assets/{Studio-D4hRKhJ1.js → Studio-BzwFDYzk.js} +2 -2
  97. package/client/assets/Studio-BzwFDYzk.js.br +0 -0
  98. package/client/assets/Studio-BzwFDYzk.js.gz +0 -0
  99. package/client/assets/{Studio-D4hRKhJ1.js.map → Studio-BzwFDYzk.js.map} +1 -1
  100. package/client/assets/StyleEditor-RZvkKHdf.js +2 -0
  101. package/client/assets/StyleEditor-RZvkKHdf.js.br +0 -0
  102. package/client/assets/StyleEditor-RZvkKHdf.js.gz +0 -0
  103. package/client/assets/{StyleEditor-BvcE8dkA.js.map → StyleEditor-RZvkKHdf.js.map} +1 -1
  104. package/client/assets/SuperscriptPeriod-DaZq1rr6.js +2 -0
  105. package/client/assets/SuperscriptPeriod-DaZq1rr6.js.br +0 -0
  106. package/client/assets/SuperscriptPeriod-DaZq1rr6.js.gz +0 -0
  107. package/client/assets/{SuperscriptPeriod-BmHAoSBy.js.map → SuperscriptPeriod-DaZq1rr6.js.map} +1 -1
  108. package/client/assets/SuperscriptTime-Mc0ZGBMo.js +2 -0
  109. package/client/assets/SuperscriptTime-Mc0ZGBMo.js.br +0 -0
  110. package/client/assets/SuperscriptTime-Mc0ZGBMo.js.gz +0 -0
  111. package/client/assets/{SuperscriptTime-Nou92D8X.js.map → SuperscriptTime-Mc0ZGBMo.js.map} +1 -1
  112. package/client/assets/{TimeElements-XpRwBsaa.js → TimeElements-dIvFHgcd.js} +2 -2
  113. package/client/assets/TimeElements-dIvFHgcd.js.br +0 -0
  114. package/client/assets/TimeElements-dIvFHgcd.js.gz +0 -0
  115. package/client/assets/{TimeElements-XpRwBsaa.js.map → TimeElements-dIvFHgcd.js.map} +1 -1
  116. package/client/assets/TimeInput-Duzx40TC.js +2 -0
  117. package/client/assets/TimeInput-Duzx40TC.js.br +0 -0
  118. package/client/assets/TimeInput-Duzx40TC.js.gz +0 -0
  119. package/client/assets/{TimeInput-Bu_5GlHP.js.map → TimeInput-Duzx40TC.js.map} +1 -1
  120. package/client/assets/{TimelinePage-CQqUB1KT.js → TimelinePage-C-OHrCR8.js} +2 -2
  121. package/client/assets/TimelinePage-C-OHrCR8.js.br +0 -0
  122. package/client/assets/TimelinePage-C-OHrCR8.js.gz +0 -0
  123. package/client/assets/{TimelinePage-CQqUB1KT.js.map → TimelinePage-C-OHrCR8.js.map} +1 -1
  124. package/client/assets/Timer-CGqVtVEC.js +2 -0
  125. package/client/assets/Timer-CGqVtVEC.js.br +0 -0
  126. package/client/assets/Timer-CGqVtVEC.js.gz +0 -0
  127. package/client/assets/{Timer-CIr2L3gJ.js.map → Timer-CGqVtVEC.js.map} +1 -1
  128. package/client/assets/{Timer-B7nk3TMf.css → Timer-Jjolf5Ra.css} +1 -1
  129. package/client/assets/Timer-Jjolf5Ra.css.br +0 -0
  130. package/client/assets/Timer-Jjolf5Ra.css.gz +0 -0
  131. package/client/assets/{TimerControlExport-4a3Cd9x8.js → TimerControlExport-GJn4WWdH.js} +2 -2
  132. package/client/assets/TimerControlExport-GJn4WWdH.js.br +0 -0
  133. package/client/assets/TimerControlExport-GJn4WWdH.js.gz +0 -0
  134. package/client/assets/{TimerControlExport-4a3Cd9x8.js.map → TimerControlExport-GJn4WWdH.js.map} +1 -1
  135. package/client/assets/TitleCard-BqbrUnHO.js +2 -0
  136. package/client/assets/TitleCard-BqbrUnHO.js.br +0 -0
  137. package/client/assets/TitleCard-BqbrUnHO.js.gz +0 -0
  138. package/client/assets/{TitleCard-1U35ek0D.js.map → TitleCard-BqbrUnHO.js.map} +1 -1
  139. package/client/assets/Tooltip-BQBvaIZx.js +2 -0
  140. package/client/assets/Tooltip-BQBvaIZx.js.br +0 -0
  141. package/client/assets/Tooltip-BQBvaIZx.js.gz +0 -0
  142. package/client/assets/{Tooltip-B8y25e3n.js.map → Tooltip-BQBvaIZx.js.map} +1 -1
  143. package/client/assets/ViewLogo-BdL1hUV1.js +2 -0
  144. package/client/assets/ViewLogo-BdL1hUV1.js.br +0 -0
  145. package/client/assets/ViewLogo-BdL1hUV1.js.gz +0 -0
  146. package/client/assets/{ViewLogo-BHsV7Faa.js.map → ViewLogo-BdL1hUV1.js.map} +1 -1
  147. package/client/assets/{ViewParamsEditor-BMHXOv-K.js → ViewParamsEditor-CFedpp6w.js} +2 -2
  148. package/client/assets/ViewParamsEditor-CFedpp6w.js.br +0 -0
  149. package/client/assets/ViewParamsEditor-CFedpp6w.js.gz +0 -0
  150. package/client/assets/{ViewParamsEditor-BMHXOv-K.js.map → ViewParamsEditor-CFedpp6w.js.map} +1 -1
  151. package/client/assets/dateConfig-BU1RZfIK.js +2 -0
  152. package/client/assets/dateConfig-BU1RZfIK.js.br +0 -0
  153. package/client/assets/dateConfig-BU1RZfIK.js.gz +0 -0
  154. package/client/assets/dateConfig-BU1RZfIK.js.map +1 -0
  155. package/client/assets/editorSettings-BMt-7s8I.js +2 -0
  156. package/client/assets/editorSettings-BMt-7s8I.js.br +0 -0
  157. package/client/assets/editorSettings-BMt-7s8I.js.gz +0 -0
  158. package/client/assets/{editorSettings-DH9ca-nB.js.map → editorSettings-BMt-7s8I.js.map} +1 -1
  159. package/client/assets/{getProgress-DlrSzpnf.js → getProgress-sdxPEEPi.js} +2 -2
  160. package/client/assets/getProgress-sdxPEEPi.js.br +0 -0
  161. package/client/assets/getProgress-sdxPEEPi.js.gz +0 -0
  162. package/client/assets/{getProgress-DlrSzpnf.js.map → getProgress-sdxPEEPi.js.map} +1 -1
  163. package/client/assets/index-CoGiopcb.js +3 -0
  164. package/client/assets/index-CoGiopcb.js.br +0 -0
  165. package/client/assets/index-CoGiopcb.js.gz +0 -0
  166. package/client/assets/index-CoGiopcb.js.map +1 -0
  167. package/client/assets/{offset-CLG4o744.js → offset-BS90Rks2.js} +2 -2
  168. package/client/assets/offset-BS90Rks2.js.br +0 -0
  169. package/client/assets/offset-BS90Rks2.js.gz +0 -0
  170. package/client/assets/{offset-CLG4o744.js.map → offset-BS90Rks2.js.map} +1 -1
  171. package/client/assets/parseUserTime-DZJMcfuJ.js +2 -0
  172. package/client/assets/parseUserTime-DZJMcfuJ.js.br +0 -0
  173. package/client/assets/parseUserTime-DZJMcfuJ.js.gz +0 -0
  174. package/client/assets/{parseUserTime-Cp5iWS7y.js.map → parseUserTime-DZJMcfuJ.js.map} +1 -1
  175. package/client/assets/{playbackstate-B3BKJ8cT.js → playbackstate-CWexoP3a.js} +2 -2
  176. package/client/assets/playbackstate-CWexoP3a.js.br +0 -0
  177. package/client/assets/playbackstate-CWexoP3a.js.gz +0 -0
  178. package/client/assets/{playbackstate-B3BKJ8cT.js.map → playbackstate-CWexoP3a.js.map} +1 -1
  179. package/client/assets/{presentation.utils-B-wIv_a5.js → presentation.utils-Zo5hNQje.js} +2 -2
  180. package/client/assets/presentation.utils-Zo5hNQje.js.br +0 -0
  181. package/client/assets/presentation.utils-Zo5hNQje.js.gz +0 -0
  182. package/client/assets/{presentation.utils-B-wIv_a5.js.map → presentation.utils-Zo5hNQje.js.map} +1 -1
  183. package/client/assets/rundownUtils-Dl1x6NDv.js +2 -0
  184. package/client/assets/rundownUtils-Dl1x6NDv.js.br +0 -0
  185. package/client/assets/rundownUtils-Dl1x6NDv.js.gz +0 -0
  186. package/client/assets/{rundownUtils-DJKMt8Ih.js.map → rundownUtils-Dl1x6NDv.js.map} +1 -1
  187. package/client/assets/timer.utils-BnMyVO6Z.js +2 -0
  188. package/client/assets/timer.utils-BnMyVO6Z.js.br +0 -0
  189. package/client/assets/timer.utils-BnMyVO6Z.js.gz +0 -0
  190. package/client/assets/timer.utils-BnMyVO6Z.js.map +1 -0
  191. package/client/assets/useCustomFields-CcTb-GQM.js +2 -0
  192. package/client/assets/useCustomFields-CcTb-GQM.js.br +0 -0
  193. package/client/assets/useCustomFields-CcTb-GQM.js.gz +0 -0
  194. package/client/assets/{useCustomFields-BUJkzZvM.js.map → useCustomFields-CcTb-GQM.js.map} +1 -1
  195. package/client/assets/useFollowComponent-BjhV6Uv8.js +2 -0
  196. package/client/assets/useFollowComponent-BjhV6Uv8.js.br +0 -0
  197. package/client/assets/useFollowComponent-BjhV6Uv8.js.gz +0 -0
  198. package/client/assets/{useFollowComponent-Eyo4hWVG.js.map → useFollowComponent-BjhV6Uv8.js.map} +1 -1
  199. package/client/assets/{useProjectData-DGA6K2Zs.js → useProjectData-B5mjXsMj.js} +2 -2
  200. package/client/assets/useProjectData-B5mjXsMj.js.br +0 -0
  201. package/client/assets/useProjectData-B5mjXsMj.js.gz +0 -0
  202. package/client/assets/{useProjectData-DGA6K2Zs.js.map → useProjectData-B5mjXsMj.js.map} +1 -1
  203. package/client/assets/useReport-zMbyWwpn.js +2 -0
  204. package/client/assets/useReport-zMbyWwpn.js.br +0 -0
  205. package/client/assets/useReport-zMbyWwpn.js.gz +0 -0
  206. package/client/assets/{useReport-BUCsRa2T.js.map → useReport-zMbyWwpn.js.map} +1 -1
  207. package/client/assets/useRundown-CHsh5rnl.js +2 -0
  208. package/client/assets/useRundown-CHsh5rnl.js.br +0 -0
  209. package/client/assets/useRundown-CHsh5rnl.js.gz +0 -0
  210. package/client/assets/useRundown-CHsh5rnl.js.map +1 -0
  211. package/client/assets/useWindowTitle-mLKt65i7.js +2 -0
  212. package/client/assets/useWindowTitle-mLKt65i7.js.br +0 -0
  213. package/client/assets/useWindowTitle-mLKt65i7.js.gz +0 -0
  214. package/client/assets/{useWindowTitle-DU8NlxIu.js.map → useWindowTitle-mLKt65i7.js.map} +1 -1
  215. package/client/assets/{validateEvent-3adKsP1N.js → validateEvent-CUmvjN95.js} +2 -2
  216. package/client/assets/validateEvent-CUmvjN95.js.br +0 -0
  217. package/client/assets/validateEvent-CUmvjN95.js.gz +0 -0
  218. package/client/assets/{validateEvent-3adKsP1N.js.map → validateEvent-CUmvjN95.js.map} +1 -1
  219. package/client/assets/{vendor-BoH5HFNN.js → vendor-Cdwxo8bP.js} +21 -21
  220. package/client/assets/vendor-Cdwxo8bP.js.br +0 -0
  221. package/client/assets/vendor-Cdwxo8bP.js.gz +0 -0
  222. package/client/assets/{vendor-BoH5HFNN.js.map → vendor-Cdwxo8bP.js.map} +1 -1
  223. package/client/assets/{viewLoader.utils-BPOG1xso.js → viewLoader.utils-DuXjY5zb.js} +2 -2
  224. package/client/assets/viewLoader.utils-DuXjY5zb.js.br +0 -0
  225. package/client/assets/viewLoader.utils-DuXjY5zb.js.gz +0 -0
  226. package/client/assets/{viewLoader.utils-BPOG1xso.js.map → viewLoader.utils-DuXjY5zb.js.map} +1 -1
  227. package/client/assets/viewUtils-dKRKkb_F.js +2 -0
  228. package/client/assets/viewUtils-dKRKkb_F.js.br +0 -0
  229. package/client/assets/viewUtils-dKRKkb_F.js.gz +0 -0
  230. package/client/assets/viewUtils-dKRKkb_F.js.map +1 -0
  231. package/client/index.html +2 -2
  232. package/package.json +1 -1
  233. package/server/index.cjs +89 -89
  234. package/client/assets/Backstage-DG-hwPI3.js +0 -2
  235. package/client/assets/Backstage-DG-hwPI3.js.br +0 -0
  236. package/client/assets/Backstage-DG-hwPI3.js.gz +0 -0
  237. package/client/assets/Countdown-C8LGl1pp.js.br +0 -0
  238. package/client/assets/Countdown-C8LGl1pp.js.gz +0 -0
  239. package/client/assets/CustomTranslationModal-CJ9-aDjl.js.br +0 -0
  240. package/client/assets/CustomTranslationModal-CJ9-aDjl.js.gz +0 -0
  241. package/client/assets/DelayIndicator-F4GdgsGh.js +0 -2
  242. package/client/assets/DelayIndicator-F4GdgsGh.js.br +0 -0
  243. package/client/assets/DelayIndicator-F4GdgsGh.js.gz +0 -0
  244. package/client/assets/EditorFeatureWrapper-eIpSr_UK.js +0 -2
  245. package/client/assets/EditorFeatureWrapper-eIpSr_UK.js.br +0 -0
  246. package/client/assets/EditorFeatureWrapper-eIpSr_UK.js.gz +0 -0
  247. package/client/assets/EditorUtils-Bd3J5Dvf.js +0 -2
  248. package/client/assets/EditorUtils-Bd3J5Dvf.js.br +0 -0
  249. package/client/assets/EditorUtils-Bd3J5Dvf.js.gz +0 -0
  250. package/client/assets/Empty-C0IdV_kI.js +0 -2
  251. package/client/assets/Empty-C0IdV_kI.js.br +0 -0
  252. package/client/assets/Empty-C0IdV_kI.js.gz +0 -0
  253. package/client/assets/EmptyPage-Ct3d0DqJ.js +0 -2
  254. package/client/assets/EmptyPage-Ct3d0DqJ.js.br +0 -0
  255. package/client/assets/EmptyPage-Ct3d0DqJ.js.gz +0 -0
  256. package/client/assets/FollowButton-BG-ycRWu.js +0 -2
  257. package/client/assets/FollowButton-BG-ycRWu.js.br +0 -0
  258. package/client/assets/FollowButton-BG-ycRWu.js.gz +0 -0
  259. package/client/assets/MessageControlExport-X-4dl9QT.js.br +0 -0
  260. package/client/assets/MessageControlExport-X-4dl9QT.js.gz +0 -0
  261. package/client/assets/MessageControlExport-X-4dl9QT.js.map +0 -1
  262. package/client/assets/MilestoneEditor-rgBQSXVU.js.br +0 -0
  263. package/client/assets/MilestoneEditor-rgBQSXVU.js.gz +0 -0
  264. package/client/assets/Modal-Bn1bZkwb.js +0 -2
  265. package/client/assets/Modal-Bn1bZkwb.js.br +0 -0
  266. package/client/assets/Modal-Bn1bZkwb.js.gz +0 -0
  267. package/client/assets/MultiPartProgressBar-Cmw-gisu.js.br +0 -0
  268. package/client/assets/MultiPartProgressBar-Cmw-gisu.js.gz +0 -0
  269. package/client/assets/OperatorExport-CJd8jmY4.js.br +0 -0
  270. package/client/assets/OperatorExport-CJd8jmY4.js.gz +0 -0
  271. package/client/assets/OverviewWrapper-1Vj3_ojX.js.br +0 -0
  272. package/client/assets/OverviewWrapper-1Vj3_ojX.js.gz +0 -0
  273. package/client/assets/PipHost-BUF7n-lT.css +0 -1
  274. package/client/assets/PipHost-BUF7n-lT.css.br +0 -0
  275. package/client/assets/PipHost-BUF7n-lT.css.gz +0 -0
  276. package/client/assets/PipHost-D7liNR4M.js +0 -2
  277. package/client/assets/PipHost-D7liNR4M.js.br +0 -0
  278. package/client/assets/PipHost-D7liNR4M.js.gz +0 -0
  279. package/client/assets/PipHost-D7liNR4M.js.map +0 -1
  280. package/client/assets/ProjectInfo-BduQgjcz.js.br +0 -0
  281. package/client/assets/ProjectInfo-BduQgjcz.js.gz +0 -0
  282. package/client/assets/ProtectRoute-Ci_AIozP.js +0 -2
  283. package/client/assets/ProtectRoute-Ci_AIozP.js.br +0 -0
  284. package/client/assets/ProtectRoute-Ci_AIozP.js.gz +0 -0
  285. package/client/assets/ProtectedCuesheet-D_zdkwM-.js.br +0 -0
  286. package/client/assets/ProtectedCuesheet-D_zdkwM-.js.gz +0 -0
  287. package/client/assets/ProtectedEditor-CNL2ig79.js.br +0 -0
  288. package/client/assets/ProtectedEditor-CNL2ig79.js.gz +0 -0
  289. package/client/assets/ProtectedEditor-CNL2ig79.js.map +0 -1
  290. package/client/assets/RundownEntry-Bs1ombtH.js +0 -2
  291. package/client/assets/RundownEntry-Bs1ombtH.js.br +0 -0
  292. package/client/assets/RundownEntry-Bs1ombtH.js.gz +0 -0
  293. package/client/assets/RundownEntry-Bs1ombtH.js.map +0 -1
  294. package/client/assets/RundownExport-BCT0ybxy.js +0 -3
  295. package/client/assets/RundownExport-BCT0ybxy.js.br +0 -0
  296. package/client/assets/RundownExport-BCT0ybxy.js.gz +0 -0
  297. package/client/assets/RundownExport-BCT0ybxy.js.map +0 -1
  298. package/client/assets/Select-B5xNi_tM.js +0 -2
  299. package/client/assets/Select-B5xNi_tM.js.br +0 -0
  300. package/client/assets/Select-B5xNi_tM.js.gz +0 -0
  301. package/client/assets/Studio-D4hRKhJ1.js.br +0 -0
  302. package/client/assets/Studio-D4hRKhJ1.js.gz +0 -0
  303. package/client/assets/StyleEditor-BvcE8dkA.js +0 -2
  304. package/client/assets/StyleEditor-BvcE8dkA.js.br +0 -3
  305. package/client/assets/StyleEditor-BvcE8dkA.js.gz +0 -0
  306. package/client/assets/SuperscriptPeriod-BmHAoSBy.js +0 -2
  307. package/client/assets/SuperscriptPeriod-BmHAoSBy.js.br +0 -0
  308. package/client/assets/SuperscriptPeriod-BmHAoSBy.js.gz +0 -0
  309. package/client/assets/SuperscriptTime-Nou92D8X.js +0 -2
  310. package/client/assets/SuperscriptTime-Nou92D8X.js.br +0 -0
  311. package/client/assets/SuperscriptTime-Nou92D8X.js.gz +0 -0
  312. package/client/assets/TimeElements-XpRwBsaa.js.br +0 -0
  313. package/client/assets/TimeElements-XpRwBsaa.js.gz +0 -0
  314. package/client/assets/TimeInput-Bu_5GlHP.js +0 -2
  315. package/client/assets/TimeInput-Bu_5GlHP.js.br +0 -0
  316. package/client/assets/TimeInput-Bu_5GlHP.js.gz +0 -0
  317. package/client/assets/TimelinePage-CQqUB1KT.js.br +0 -0
  318. package/client/assets/TimelinePage-CQqUB1KT.js.gz +0 -0
  319. package/client/assets/Timer-B7nk3TMf.css.br +0 -0
  320. package/client/assets/Timer-B7nk3TMf.css.gz +0 -0
  321. package/client/assets/Timer-CIr2L3gJ.js +0 -2
  322. package/client/assets/Timer-CIr2L3gJ.js.br +0 -0
  323. package/client/assets/Timer-CIr2L3gJ.js.gz +0 -0
  324. package/client/assets/TimerControlExport-4a3Cd9x8.js.br +0 -0
  325. package/client/assets/TimerControlExport-4a3Cd9x8.js.gz +0 -0
  326. package/client/assets/TitleCard-1U35ek0D.js +0 -2
  327. package/client/assets/TitleCard-1U35ek0D.js.br +0 -0
  328. package/client/assets/TitleCard-1U35ek0D.js.gz +0 -0
  329. package/client/assets/Tooltip-B8y25e3n.js +0 -2
  330. package/client/assets/Tooltip-B8y25e3n.js.br +0 -0
  331. package/client/assets/Tooltip-B8y25e3n.js.gz +0 -0
  332. package/client/assets/ViewLogo-BHsV7Faa.js +0 -2
  333. package/client/assets/ViewLogo-BHsV7Faa.js.br +0 -0
  334. package/client/assets/ViewLogo-BHsV7Faa.js.gz +0 -0
  335. package/client/assets/ViewParamsEditor-BMHXOv-K.js.br +0 -0
  336. package/client/assets/ViewParamsEditor-BMHXOv-K.js.gz +0 -0
  337. package/client/assets/dateConfig-_BhycZza.js +0 -2
  338. package/client/assets/dateConfig-_BhycZza.js.br +0 -0
  339. package/client/assets/dateConfig-_BhycZza.js.gz +0 -0
  340. package/client/assets/dateConfig-_BhycZza.js.map +0 -1
  341. package/client/assets/editorSettings-DH9ca-nB.js +0 -2
  342. package/client/assets/editorSettings-DH9ca-nB.js.br +0 -0
  343. package/client/assets/editorSettings-DH9ca-nB.js.gz +0 -0
  344. package/client/assets/getProgress-DlrSzpnf.js.br +0 -0
  345. package/client/assets/getProgress-DlrSzpnf.js.gz +0 -0
  346. package/client/assets/index-CDBQg2fh.js +0 -3
  347. package/client/assets/index-CDBQg2fh.js.br +0 -0
  348. package/client/assets/index-CDBQg2fh.js.gz +0 -0
  349. package/client/assets/index-CDBQg2fh.js.map +0 -1
  350. package/client/assets/offset-CLG4o744.js.br +0 -0
  351. package/client/assets/offset-CLG4o744.js.gz +0 -0
  352. package/client/assets/parseUserTime-Cp5iWS7y.js +0 -2
  353. package/client/assets/parseUserTime-Cp5iWS7y.js.br +0 -0
  354. package/client/assets/parseUserTime-Cp5iWS7y.js.gz +0 -0
  355. package/client/assets/playbackstate-B3BKJ8cT.js.br +0 -0
  356. package/client/assets/playbackstate-B3BKJ8cT.js.gz +0 -0
  357. package/client/assets/presentation.utils-B-wIv_a5.js.br +0 -0
  358. package/client/assets/presentation.utils-B-wIv_a5.js.gz +0 -0
  359. package/client/assets/rundownUtils-DJKMt8Ih.js +0 -2
  360. package/client/assets/rundownUtils-DJKMt8Ih.js.br +0 -0
  361. package/client/assets/rundownUtils-DJKMt8Ih.js.gz +0 -0
  362. package/client/assets/timer.utils-ByC_bcT9.js +0 -2
  363. package/client/assets/timer.utils-ByC_bcT9.js.br +0 -0
  364. package/client/assets/timer.utils-ByC_bcT9.js.gz +0 -0
  365. package/client/assets/timer.utils-ByC_bcT9.js.map +0 -1
  366. package/client/assets/useCustomFields-BUJkzZvM.js +0 -2
  367. package/client/assets/useCustomFields-BUJkzZvM.js.br +0 -2
  368. package/client/assets/useCustomFields-BUJkzZvM.js.gz +0 -0
  369. package/client/assets/useFollowComponent-Eyo4hWVG.js +0 -2
  370. package/client/assets/useFollowComponent-Eyo4hWVG.js.br +0 -0
  371. package/client/assets/useFollowComponent-Eyo4hWVG.js.gz +0 -0
  372. package/client/assets/useProjectData-DGA6K2Zs.js.br +0 -0
  373. package/client/assets/useProjectData-DGA6K2Zs.js.gz +0 -0
  374. package/client/assets/useReport-BUCsRa2T.js +0 -2
  375. package/client/assets/useReport-BUCsRa2T.js.br +0 -0
  376. package/client/assets/useReport-BUCsRa2T.js.gz +0 -0
  377. package/client/assets/useRundown-BFae0_bU.js +0 -2
  378. package/client/assets/useRundown-BFae0_bU.js.br +0 -0
  379. package/client/assets/useRundown-BFae0_bU.js.gz +0 -0
  380. package/client/assets/useRundown-BFae0_bU.js.map +0 -1
  381. package/client/assets/useWindowTitle-DU8NlxIu.js +0 -2
  382. package/client/assets/useWindowTitle-DU8NlxIu.js.br +0 -0
  383. package/client/assets/useWindowTitle-DU8NlxIu.js.gz +0 -0
  384. package/client/assets/validateEvent-3adKsP1N.js.br +0 -0
  385. package/client/assets/validateEvent-3adKsP1N.js.gz +0 -0
  386. package/client/assets/vendor-BoH5HFNN.js.br +0 -0
  387. package/client/assets/vendor-BoH5HFNN.js.gz +0 -0
  388. package/client/assets/viewLoader.utils-BPOG1xso.js.br +0 -0
  389. package/client/assets/viewLoader.utils-BPOG1xso.js.gz +0 -0
  390. package/client/assets/viewUtils-DI8_kmUZ.js +0 -2
  391. package/client/assets/viewUtils-DI8_kmUZ.js.br +0 -0
  392. package/client/assets/viewUtils-DI8_kmUZ.js.gz +0 -0
  393. package/client/assets/viewUtils-DI8_kmUZ.js.map +0 -1
@@ -1 +1 @@
1
- {"version":3,"file":"ProtectedCuesheet-D_zdkwM-.js","sources":["../../src/common/hooks/useIsMobileScreen.ts","../../src/features/overview/CuesheetOverview.tsx","../../src/features/rundown/entry-editor/CuesheetEventEditor.tsx","../../src/views/cuesheet/cuesheet-edit-modal/useCuesheetEditModal.tsx","../../src/views/cuesheet/cuesheet-edit-modal/CuesheetEditModal.tsx","../../src/views/cuesheet/cuesheet-progress/CuesheetProgress.tsx","../../src/common/utils/debounce.ts","../../src/views/cuesheet/cuesheet-table/useColumnManager.tsx","../../src/views/cuesheet/cuesheet-dnd/CuesheetDnd.tsx","../../src/views/cuesheet/cuesheet-table/cuesheet-table-elements/SingleLineCell.tsx","../../src/views/cuesheet/cuesheet-table/cuesheet-table-elements/DurationInput.tsx","../../src/views/cuesheet/cuesheet-table/cuesheet-table-elements/EditableImage.tsx","../../src/views/cuesheet/cuesheet-table/cuesheet-table-elements/FlagCell.tsx","../../src/views/cuesheet/cuesheet-table/cuesheet-table-elements/GhostedText.tsx","../../src/views/cuesheet/cuesheet-table/cuesheet-table-elements/MultiLineCell.tsx","../../src/views/cuesheet/cuesheet-table/cuesheet-table-elements/MutedText.tsx","../../src/views/cuesheet/cuesheet-table/cuesheet-table-elements/TimeInput.tsx","../../src/views/cuesheet/cuesheet-table/cuesheet-table-elements/cuesheetColsFactory.tsx","../../src/common/components/state/EmptyTableBody.tsx","../../src/views/cuesheet/cuesheet-table/cuesheet-table-elements/SortableCell.tsx","../../src/views/cuesheet/cuesheet-table/cuesheet-table-elements/CuesheetHeader.tsx","../../src/views/cuesheet/cuesheet-table/cuesheet-table-elements/DelayRow.tsx","../../src/views/cuesheet/cuesheet-table/cuesheet-table-menu/useCuesheetTableMenu.tsx","../../src/views/cuesheet/cuesheet-table/cuesheet-table-elements/EventRow.tsx","../../src/views/cuesheet/cuesheet-table/cuesheet-table-elements/GroupRow.tsx","../../src/views/cuesheet/cuesheet-table/cuesheet-table-elements/MilestoneRow.tsx","../../src/views/cuesheet/useTablePermissions.tsx","../../src/views/cuesheet/cuesheet-table/cuesheet-table-menu/CuesheetTableMenu.tsx","../../src/common/components/icons/RotatedLink.tsx","../../src/views/cuesheet/cuesheet-table/cuesheet-table-settings/CuesheetShareModal.tsx","../../src/views/cuesheet/cuesheet-table/cuesheet-table-settings/CuesheetTableSettings.tsx","../../src/views/cuesheet/cuesheet-table/CuesheetTable.tsx","../../src/views/cuesheet/CuesheetTableWrapper.tsx","../../src/views/cuesheet/CuesheetPage.tsx","../../src/views/cuesheet/ProtectedCuesheet.tsx"],"sourcesContent":["import { useMemo } from 'react';\nimport { useViewportSize } from '@mantine/hooks';\n\nexport function useIsMobileScreen(): boolean {\n const { width } = useViewportSize();\n\n return useMemo(() => width < 800, [width]);\n}\n","import { memo, PropsWithChildren } from 'react';\n\nimport { useIsMobileScreen } from '../../common/hooks/useIsMobileScreen';\n\nimport { ClockOverview, MetadataTimes, OffsetOverview, StartTimes, TimerOverview } from './composite/TimeElements';\nimport TitleOverview from './composite/TitleOverview';\nimport { OverviewWrapper } from './OverviewWrapper';\n\nexport default memo(CuesheetOverview);\nfunction CuesheetOverview({ children }: PropsWithChildren) {\n const isMobileScreen = useIsMobileScreen();\n\n if (isMobileScreen) return <CuesheetMobile>{children}</CuesheetMobile>;\n else return <CuesheetDesktop>{children}</CuesheetDesktop>;\n}\n\nfunction CuesheetMobile({ children }: PropsWithChildren) {\n return (\n <OverviewWrapper navElements={children}>\n <TimerOverview />\n <OffsetOverview />\n </OverviewWrapper>\n );\n}\n\nfunction CuesheetDesktop({ children }: PropsWithChildren) {\n return (\n <OverviewWrapper navElements={children}>\n <TitleOverview />\n <StartTimes shouldFormat />\n <TimerOverview />\n <OffsetOverview />\n <MetadataTimes />\n <ClockOverview shouldFormat />\n </OverviewWrapper>\n );\n}\n","import { useEffect, useState } from 'react';\nimport { isOntimeEvent, isOntimeGroup, isOntimeMilestone, OntimeEntry } from 'ontime-types';\n\nimport useRundown from '../../../common/hooks-query/useRundown';\n\nimport EventEditor from './EventEditor';\nimport GroupEditor from './GroupEditor';\nimport MilestoneEditor from './MilestoneEditor';\n\nimport style from './EntryEditor.module.scss';\n\ninterface CuesheetEntryEditorProps {\n entryId: string;\n}\n\nexport default function CuesheetEntryEditor({ entryId }: CuesheetEntryEditorProps) {\n const { data } = useRundown();\n const [entry, setEntry] = useState<OntimeEntry | null>(null);\n\n useEffect(() => {\n if (data.order.length === 0) {\n setEntry(null);\n return;\n }\n\n const event = data.entries[entryId];\n if (event) {\n setEntry(event);\n } else {\n setEntry(null);\n }\n }, [entryId, data.order, data.entries]);\n\n if (isOntimeEvent(entry)) {\n return (\n <div className={style.entryEditor} data-testid='editor-container'>\n <EventEditor event={entry} />\n </div>\n );\n }\n\n if (isOntimeMilestone(entry)) {\n return (\n <div className={style.inModal} data-testid='editor-container'>\n <MilestoneEditor milestone={entry} />\n </div>\n );\n }\n\n if (isOntimeGroup(entry)) {\n return (\n <div className={style.inModal} data-testid='editor-container'>\n <GroupEditor group={entry} />\n </div>\n );\n }\n\n return null;\n}\n","import { EntryId } from 'ontime-types';\nimport { create } from 'zustand';\n\ninterface SelectedEntryState {\n selectedEntryId: EntryId | null;\n setEditableEntry: (entryId: EntryId) => void;\n clearSelection: () => void;\n}\n\nexport const useCuesheetEditModal = create<SelectedEntryState>((set) => ({\n selectedEntryId: null,\n setEditableEntry: (entryId: EntryId) => set({ selectedEntryId: entryId }),\n clearSelection: () => set({ selectedEntryId: null }),\n}));\n","import { memo } from 'react';\n\nimport Modal from '../../../common/components/modal/Modal';\nimport CuesheetEntryEditor from '../../../features/rundown/entry-editor/CuesheetEventEditor';\n\nimport { useCuesheetEditModal } from './useCuesheetEditModal';\n\nexport default memo(CuesheetEditModal);\nfunction CuesheetEditModal() {\n const entryId = useCuesheetEditModal((state) => state.selectedEntryId);\n const closeModal = useCuesheetEditModal((state) => state.clearSelection);\n\n if (entryId === null) {\n return null;\n }\n\n return (\n <Modal\n isOpen\n onClose={closeModal}\n title='Edit entry'\n showCloseButton\n bodyElements={<CuesheetEntryEditor entryId={entryId} />}\n />\n );\n}\n","import MultiPartProgressBar from '../../../common/components/multi-part-progress-bar/MultiPartProgressBar';\nimport { useProgressData } from '../../../common/hooks/useSocket';\nimport useViewSettings from '../../../common/hooks-query/useViewSettings';\n\nimport styles from './CuesheetProgress.module.scss';\n\nexport default function CuesheetProgress() {\n const { data } = useViewSettings();\n const { current, duration, timeWarning, timeDanger } = useProgressData();\n\n return (\n <MultiPartProgressBar\n now={current}\n complete={duration}\n normalColor={data.normalColor}\n warning={timeWarning}\n warningColor={data.warningColor}\n danger={timeDanger}\n dangerColor={data.dangerColor}\n className={styles.progressOverride}\n ignoreCssOverride\n />\n );\n}\n","export function debounce<T extends any[]>(callback: (...args: T) => void, wait: number) {\n let timeout: NodeJS.Timeout | null;\n return (...args: T) => {\n if (timeout) {\n clearTimeout(timeout);\n }\n timeout = setTimeout(() => {\n timeout = null;\n callback(...args);\n }, wait);\n };\n}\n","import { useCallback, useEffect, useState } from 'react';\nimport { useLocalStorage } from '@mantine/hooks';\nimport { ColumnDef, ColumnSizingState, Updater } from '@tanstack/react-table';\n\nimport { debounce } from '../../../common/utils/debounce';\nimport { makeStageKey } from '../../../common/utils/localStorage';\nimport type { ExtendedEntry } from '../../../common/utils/rundownMetadata';\n\nconst tableSizesKey = makeStageKey('cuesheet-sizes');\nconst tableHiddenKey = makeStageKey('cuesheet-hidden');\nconst tableOrderKey = makeStageKey('cuesheet-order');\n\nconst saveSizesToStorage = debounce((sizes: Record<string, number>) => {\n localStorage.setItem(tableSizesKey, JSON.stringify(sizes));\n}, 500);\n\nexport function useColumnSizes() {\n const [columnSizing, setColumnSizingState] = useState<Record<string, number>>(() => {\n try {\n const stored = localStorage.getItem(tableSizesKey);\n return stored ? JSON.parse(stored) : {};\n } catch {\n return {};\n }\n });\n\n // save sizes to localStorage whenever they change (debounced)\n useEffect(() => {\n saveSizesToStorage(columnSizing);\n }, [columnSizing]);\n\n const setColumnSizing = useCallback((sizesOrUpdater: Updater<ColumnSizingState>) => {\n setColumnSizingState(sizesOrUpdater);\n }, []);\n\n return {\n columnSizing,\n setColumnSizing,\n };\n}\n\nexport function useColumnOrder(columns: ColumnDef<ExtendedEntry>[]) {\n const [columnOrder, saveColumnOrder] = useLocalStorage<string[]>({\n key: tableOrderKey,\n defaultValue: columns.map((col) => col.id as string),\n });\n\n // update column order if columns change\n useEffect(() => {\n const newColumns = columns.map((col) => col.id as string);\n if (newColumns.some((id) => !columnOrder.includes(id))) {\n saveColumnOrder(newColumns);\n }\n }, [columnOrder, columns, saveColumnOrder]);\n\n const resetColumnOrder = useCallback(() => {\n saveColumnOrder(columns.map((col) => col.id as string));\n }, [columns, saveColumnOrder]);\n\n return {\n columnOrder,\n saveColumnOrder,\n resetColumnOrder,\n };\n}\n\nexport function useColumnVisibility() {\n const [columnVisibility, setColumnVisibility] = useLocalStorage({\n key: tableHiddenKey,\n defaultValue: {},\n });\n\n return {\n columnVisibility,\n setColumnVisibility,\n };\n}\n","import { PropsWithChildren } from 'react';\nimport {\n closestCorners,\n DndContext,\n DragEndEvent,\n PointerSensor,\n TouchSensor,\n useSensor,\n useSensors,\n} from '@dnd-kit/core';\nimport { ColumnDef } from '@tanstack/react-table';\n\nimport type { ExtendedEntry } from '../../../common/utils/rundownMetadata';\nimport { useColumnOrder } from '../cuesheet-table/useColumnManager';\n\ninterface CuesheetDndProps {\n columns: ColumnDef<ExtendedEntry>[];\n}\n\nexport default function CuesheetDnd({ columns, children }: PropsWithChildren<CuesheetDndProps>) {\n const { columnOrder, saveColumnOrder } = useColumnOrder(columns);\n\n const sensors = useSensors(\n useSensor(PointerSensor, {\n activationConstraint: {\n delay: 100,\n tolerance: 50,\n },\n }),\n useSensor(TouchSensor, {\n activationConstraint: {\n delay: 100,\n tolerance: 50,\n },\n }),\n );\n\n const handleOnDragEnd = (event: DragEndEvent) => {\n const { delta, active, over } = event;\n\n // cancel if delta y is greater than 200\n if (delta.y > 200) return;\n // cancel if we do not have an over id\n if (over?.id == null) return;\n\n // get index of from\n const fromIndex = columnOrder.indexOf(active.id as string);\n\n // get index of to\n const toIndex = columnOrder.indexOf(over.id as string);\n\n if (toIndex === -1) {\n return;\n }\n\n const reorderedCols = [...columnOrder];\n const reorderedItem = reorderedCols.splice(fromIndex, 1);\n reorderedCols.splice(toIndex, 0, reorderedItem[0]);\n saveColumnOrder(reorderedCols);\n };\n\n return (\n <DndContext sensors={sensors} collisionDetection={closestCorners} onDragEnd={handleOnDragEnd}>\n {children}\n </DndContext>\n );\n}\n","import { forwardRef, memo, useCallback, useImperativeHandle, useRef } from 'react';\n\nimport Input from '../../../../common/components/input/input/Input';\nimport useReactiveTextInput from '../../../../common/components/input/text-input/useReactiveTextInput';\n\ninterface SingleLineCellProps {\n initialValue: string;\n allowSubmitSameValue?: boolean;\n handleUpdate: (newValue: string) => void;\n handleCancelUpdate?: () => void;\n}\n\nconst SingleLineCell = forwardRef(\n ({ initialValue, allowSubmitSameValue, handleUpdate, handleCancelUpdate }: SingleLineCellProps, inputRef) => {\n const ref = useRef<HTMLInputElement | null>(null);\n const submitCallback = useCallback((newValue: string) => handleUpdate(newValue), [handleUpdate]);\n\n const { value, onChange, onBlur, onKeyDown } = useReactiveTextInput(initialValue, submitCallback, ref, {\n allowSubmitSameValue,\n allowKeyboardNavigation: true,\n submitOnEnter: true, // single line should submit on enter\n submitOnCtrlEnter: true,\n onCancelUpdate: handleCancelUpdate,\n });\n\n // expose a subset of the methods to the parent\n useImperativeHandle(inputRef, () => {\n return {\n focus() {\n ref.current?.focus();\n },\n select() {\n ref.current?.select();\n },\n focusParentElement() {\n ref.current?.parentElement?.focus();\n },\n };\n }, [ref]);\n\n return (\n <Input\n ref={ref}\n variant='ghosted'\n fluid\n value={value}\n onChange={onChange}\n onBlur={onBlur}\n onKeyDown={onKeyDown}\n />\n );\n },\n);\n\nSingleLineCell.displayName = 'SingleLineCell';\n\nexport default memo(SingleLineCell);\n","import { memo, PropsWithChildren, useCallback, useEffect, useRef, useState } from 'react';\nimport { millisToString, parseUserTime } from 'ontime-utils';\n\nimport SingleLineCell from './SingleLineCell';\nimport TextLikeInput from './TextLikeInput';\n\ninterface DurationInputProps {\n initialValue: number;\n lockedValue: boolean;\n delayed?: boolean;\n onSubmit: (value: string) => void;\n}\n\ninterface ParentFocusableInput extends HTMLInputElement {\n focusParentElement: () => void;\n}\n\nexport default memo(DurationInput);\n\nfunction DurationInput({\n initialValue,\n lockedValue,\n delayed,\n onSubmit,\n children,\n}: PropsWithChildren<DurationInputProps>) {\n const [isEditing, setIsEditing] = useState(false);\n const [value, setValue] = useState(initialValue);\n const inputRef = useRef<ParentFocusableInput>(null);\n const textRef = useRef<ParentFocusableInput>(null);\n\n // when we go into edit mode, set focus to the input\n useEffect(() => {\n if (isEditing && inputRef.current) {\n inputRef.current.focus();\n inputRef.current.select();\n }\n }, [isEditing]);\n\n // reset value when initialValue changes, avoiding interrupting the user if we are in edit mode\n useEffect(() => {\n if (!isEditing) {\n setValue(initialValue);\n }\n }, [initialValue, isEditing]);\n\n const handleFakeFocus = () => setIsEditing(true);\n const handleFakeBlur = () => {\n setIsEditing(false);\n setTimeout(() => textRef.current?.focusParentElement()); // Immediate timeout to ensure state change takes place first\n };\n\n const handleUpdate = useCallback(\n (newValue: string) => {\n setIsEditing(false);\n\n // if the user sends an empty string, we want to clear the value\n if (newValue === '') {\n onSubmit(newValue);\n inputRef.current?.focusParentElement();\n return;\n }\n\n // we dont know the values in the rundown, escalate to handler\n if (newValue.startsWith('p') || newValue.startsWith('+')) {\n onSubmit(newValue);\n inputRef.current?.focusParentElement();\n return;\n }\n\n const valueInMillis = parseUserTime(newValue);\n if (valueInMillis < 0 || isNaN(valueInMillis)) {\n setValue(initialValue);\n setTimeout(() => textRef.current?.focusParentElement()); // Immediate timeout to ensure state change takes place first\n return;\n }\n\n // if the value is the same, we may still want to push the lock change\n if (valueInMillis === initialValue && lockedValue) {\n inputRef.current?.focusParentElement();\n return;\n }\n\n onSubmit(newValue);\n setValue(Number(newValue));\n setTimeout(() => textRef.current?.focusParentElement()); // Immediate timeout to ensure state change takes place first\n },\n [initialValue, lockedValue, onSubmit],\n );\n\n const timeString = millisToString(value);\n\n return isEditing ? (\n <SingleLineCell\n ref={inputRef}\n initialValue={timeString}\n allowSubmitSameValue={!lockedValue} // if the value is not locked, submitting will lock the value\n handleUpdate={handleUpdate}\n handleCancelUpdate={handleFakeBlur}\n />\n ) : (\n <TextLikeInput\n onClick={handleFakeFocus}\n onFocus={handleFakeFocus}\n muted={!lockedValue}\n offset={delayed ? 'over' : undefined}\n ref={textRef}\n >\n {children}\n </TextLikeInput>\n );\n}\n","import { memo } from 'react';\n\nimport Button from '../../../../common/components/buttons/Button';\nimport Input from '../../../../common/components/input/input/Input';\n\nimport style from './EditableImage.module.scss';\n\ninterface EditableImageProps {\n initialValue: string;\n readOnly?: boolean;\n updateValue: (newValue: string) => void;\n}\n\nexport default memo(EditableImage);\n\nfunction EditableImage({ initialValue, readOnly, updateValue }: EditableImageProps) {\n const handleUpdate = (newValue: string) => {\n if (newValue === initialValue) {\n return;\n }\n if (newValue !== '' && !newValue.startsWith('http')) {\n return;\n }\n updateValue(newValue);\n };\n\n const openInNewTab = () => {\n if (initialValue) {\n window.open(initialValue, '_blank', 'noopener,noreferrer');\n }\n };\n\n if (!initialValue) {\n return (\n <Input\n variant='ghosted'\n className={style.imageInput}\n fluid\n readOnly={readOnly}\n // we disable the field to prevent receiving focus\n disabled={readOnly}\n placeholder='Paste image URL'\n onBlur={(event) => handleUpdate(event.currentTarget.value)}\n onKeyDown={(event) => {\n if (event.key === 'Enter') {\n handleUpdate(event.currentTarget.value);\n }\n }}\n defaultValue={initialValue}\n />\n );\n }\n\n return (\n <div className={style.imageCell}>\n {!readOnly && (\n <div className={style.overlay}>\n <Button onClick={openInNewTab}>Preview</Button>\n <Button variant='subtle-destructive' onClick={() => handleUpdate('')}>\n Delete\n </Button>\n </div>\n )}\n {Boolean(initialValue) && <img loading='lazy' src={initialValue} className={style.image} />}\n </div>\n );\n}\n","import { TbFlagFilled } from 'react-icons/tb';\n\nimport style from './FlagCell.module.scss';\n\nexport default function FlagCell() {\n return (\n <div className={style.flag}>\n <TbFlagFilled />\n </div>\n );\n}\n","import { PropsWithChildren } from 'react';\n\nimport style from './GhostedText.module.scss';\n\ninterface GhostedTextProps {\n multiline?: boolean;\n}\n\nexport default function GhostedText({ children, multiline }: PropsWithChildren<GhostedTextProps>) {\n return <div className={`${style.ghostedText} ${multiline ? style.multiline : ''}`}>{children}</div>;\n}\n","import { memo, useCallback, useRef } from 'react';\n\nimport { AutoTextarea } from '../../../../common/components/input/auto-textarea/AutoTextarea';\nimport useReactiveTextInput from '../../../../common/components/input/text-input/useReactiveTextInput';\n\ninterface MultiLineCellProps {\n initialValue: string;\n handleUpdate: (newValue: string) => void;\n}\n\nexport default memo(MultiLineCell);\n\nfunction MultiLineCell({ initialValue, handleUpdate }: MultiLineCellProps) {\n const ref = useRef<HTMLTextAreaElement | null>(null);\n const submitCallback = useCallback((newValue: string) => handleUpdate(newValue), [handleUpdate]);\n\n const { value, onChange, onBlur, onKeyDown } = useReactiveTextInput(initialValue, submitCallback, ref, {\n submitOnCtrlEnter: true,\n allowKeyboardNavigation: true,\n });\n\n return (\n <AutoTextarea\n inputref={ref}\n variant='ghosted'\n fluid\n rows={1}\n value={value}\n onChange={onChange}\n onBlur={onBlur}\n onKeyDown={onKeyDown}\n spellCheck={false}\n />\n );\n}\n","import { PropsWithChildren } from 'react';\n\nimport { cx } from '../../../../common/utils/styleUtils';\n\nimport style from './MutedText.module.scss';\n\ninterface MutedTextProps {\n numeric?: boolean;\n}\n\nexport default function MutedText({ numeric, children }: PropsWithChildren<MutedTextProps>) {\n return <span className={cx([style.muted, numeric && style.numeric])}>{children}</span>;\n}\n","import { memo, PropsWithChildren, useCallback, useEffect, useRef, useState } from 'react';\nimport { parseUserTime } from 'ontime-utils';\n\nimport { formatTime } from '../../../../common/utils/time';\n\nimport SingleLineCell from './SingleLineCell';\nimport TextLikeInput from './TextLikeInput';\n\ninterface TimeInputDurationProps {\n initialValue: number;\n lockedValue: boolean;\n delayed?: boolean;\n onSubmit: (value: string) => void;\n}\n\ninterface ParentFocusableInput extends HTMLInputElement {\n focusParentElement: () => void;\n}\n\nexport default memo(TimeInputDuration);\n\nfunction TimeInputDuration({\n initialValue,\n lockedValue,\n delayed,\n onSubmit,\n children,\n}: PropsWithChildren<TimeInputDurationProps>) {\n const [isEditing, setIsEditing] = useState(false);\n const [value, setValue] = useState(initialValue);\n const inputRef = useRef<ParentFocusableInput>(null);\n const textRef = useRef<ParentFocusableInput>(null);\n\n // when we go into edit mode, set focus to the input\n useEffect(() => {\n if (isEditing && inputRef.current) {\n inputRef.current.focus();\n inputRef.current.select();\n }\n }, [isEditing]);\n\n // reset value when initialValue changes, avoiding interrupting the user if we are in edit mode\n useEffect(() => {\n if (!isEditing) {\n setValue(initialValue);\n }\n }, [initialValue, isEditing]);\n\n const handleFakeFocus = () => setIsEditing(true);\n const handleFakeBlur = () => {\n setIsEditing(false);\n setTimeout(() => textRef.current?.focusParentElement()); // Immediate timeout to ensure state change takes place first\n };\n\n const handleUpdate = useCallback(\n (newValue: string) => {\n setIsEditing(false);\n\n // if the user sends an empty string, we want to clear the value\n if (newValue === '') {\n onSubmit(newValue);\n inputRef.current?.focusParentElement();\n return;\n }\n\n // we dont know the values in the rundown, escalate to handler\n if (newValue.startsWith('p') || newValue.startsWith('+')) {\n onSubmit(newValue);\n inputRef.current?.focusParentElement();\n return;\n }\n\n const valueInMillis = parseUserTime(newValue);\n if (valueInMillis < 0 || isNaN(valueInMillis)) {\n setValue(initialValue);\n setTimeout(() => textRef.current?.focusParentElement()); // Immediate timeout to ensure state change takes place first\n return;\n }\n\n // if the value is the same, we may still want to push the lock change\n if (valueInMillis === initialValue && lockedValue) {\n inputRef.current?.focusParentElement();\n return;\n }\n\n onSubmit(newValue);\n setValue(Number(newValue));\n setTimeout(() => textRef.current?.focusParentElement()); // Immediate timeout to ensure state change takes place first\n },\n [initialValue, lockedValue, onSubmit],\n );\n\n const timeString = formatTime(value);\n\n return isEditing ? (\n <SingleLineCell\n ref={inputRef}\n initialValue={timeString}\n allowSubmitSameValue={!lockedValue} // if the value is not locked, submitting will lock the value\n handleUpdate={handleUpdate}\n handleCancelUpdate={handleFakeBlur}\n />\n ) : (\n <TextLikeInput\n onClick={handleFakeFocus}\n onFocus={handleFakeFocus}\n muted={!lockedValue}\n offset={delayed ? 'over' : undefined}\n ref={textRef}\n >\n {children}\n </TextLikeInput>\n );\n}\n","import { useCallback } from 'react';\nimport { CellContext, ColumnDef } from '@tanstack/react-table';\nimport { CustomFields, isOntimeDelay, isOntimeEvent, TimeStrategy, URLPreset } from 'ontime-types';\nimport { millisToString } from 'ontime-utils';\n\nimport DelayIndicator from '../../../../common/components/delay-indicator/DelayIndicator';\nimport type { ExtendedEntry } from '../../../../common/utils/rundownMetadata';\nimport { formatDuration, formatTime } from '../../../../common/utils/time';\nimport { AppMode } from '../../../../ontimeConfig';\n\nimport DurationInput from './DurationInput';\nimport EditableImage from './EditableImage';\nimport FlagCell from './FlagCell';\nimport GhostedText from './GhostedText';\nimport MultiLineCell from './MultiLineCell';\nimport MutedText from './MutedText';\nimport SingleLineCell from './SingleLineCell';\nimport TimeInput from './TimeInput';\n\nfunction MakeStart({ getValue, row, table, column }: CellContext<ExtendedEntry, unknown>) {\n if (!table.options.meta) {\n return null;\n }\n\n const { showDelayedTimes, hideTableSeconds } = table.options.meta.options;\n const formatOpts = hideTableSeconds ? { format12: 'h:mm a', format24: 'HH:mm' } : undefined;\n\n const event = row.original;\n if (!isOntimeEvent(event)) {\n return <MutedText numeric>{formatTime(getValue() as number, formatOpts)}</MutedText>;\n }\n\n const { handleUpdateTimer } = table.options.meta;\n\n const update = (newValue: string) => handleUpdateTimer(row.original.id, 'timeStart', newValue);\n\n const startTime = getValue() as number;\n const isStartLocked = !event.linkStart;\n const displayTime = showDelayedTimes ? startTime + event.delay : startTime;\n const formattedTime = formatTime(displayTime, formatOpts);\n\n const canWrite = column.columnDef.meta?.canWrite;\n if (!canWrite) {\n return (\n <MutedText numeric>\n {formattedTime}\n <DelayIndicator delayValue={event.delay} tooltipPrefix={millisToString(startTime)} />\n </MutedText>\n );\n }\n return (\n <TimeInput initialValue={startTime} onSubmit={update} lockedValue={isStartLocked} delayed={event.delay !== 0}>\n {formattedTime}\n <DelayIndicator delayValue={event.delay} tooltipPrefix={millisToString(startTime)} />\n </TimeInput>\n );\n}\n\nfunction MakeEnd({ getValue, row, table, column }: CellContext<ExtendedEntry, unknown>) {\n if (!table.options.meta) {\n return null;\n }\n\n const { showDelayedTimes, hideTableSeconds } = table.options.meta.options;\n const formatOpts = hideTableSeconds ? { format12: 'h:mm a', format24: 'HH:mm' } : undefined;\n\n const event = row.original;\n if (!isOntimeEvent(event)) {\n return <MutedText numeric>{formatTime(getValue() as number, formatOpts)}</MutedText>;\n }\n\n const { handleUpdateTimer } = table.options.meta;\n\n const update = (newValue: string) => handleUpdateTimer(row.original.id, 'timeEnd', newValue);\n\n const endTime = getValue() as number;\n const isEndLocked = event.timeStrategy === TimeStrategy.LockEnd;\n const displayTime = showDelayedTimes ? endTime + event.delay : endTime;\n const formattedTime = formatTime(displayTime, formatOpts);\n\n const canWrite = column.columnDef.meta?.canWrite;\n if (!canWrite) {\n return (\n <MutedText numeric>\n {formattedTime}\n <DelayIndicator delayValue={event.delay} tooltipPrefix={millisToString(endTime)} />\n </MutedText>\n );\n }\n\n return (\n <TimeInput initialValue={endTime} onSubmit={update} lockedValue={isEndLocked} delayed={event.delay !== 0}>\n {formattedTime}\n <DelayIndicator delayValue={event.delay} tooltipPrefix={millisToString(endTime)} />\n </TimeInput>\n );\n}\n\nfunction MakeDuration({ getValue, row, table, column }: CellContext<ExtendedEntry, unknown>) {\n if (!table.options.meta) {\n return null;\n }\n\n const { hideTableSeconds } = table.options.meta.options;\n const event = row.original;\n if (!isOntimeEvent(event)) {\n return <MutedText numeric>{formatDuration(getValue() as number, hideTableSeconds)}</MutedText>;\n }\n\n const { handleUpdateTimer } = table.options.meta;\n\n const update = (newValue: string) => handleUpdateTimer(row.original.id, 'duration', newValue);\n\n const duration = getValue() as number;\n const isDurationLocked = event.timeStrategy === TimeStrategy.LockDuration;\n const formattedDuration = formatDuration(duration, hideTableSeconds);\n\n const canWrite = column.columnDef.meta?.canWrite;\n if (!canWrite) {\n return <MutedText numeric>{formattedDuration}</MutedText>;\n }\n\n return (\n <DurationInput initialValue={duration} onSubmit={update} lockedValue={isDurationLocked}>\n {formattedDuration}\n </DurationInput>\n );\n}\n\nfunction MakeMultiLineField({ row, column, table }: CellContext<ExtendedEntry, unknown>) {\n const update = useCallback(\n (newValue: string) => {\n table.options.meta?.handleUpdate(row.index, column.id, newValue, false);\n },\n [column.id, row.index, table.options.meta],\n );\n\n // not all entries have all properties (eg groups)\n const initialValue = row.original[column.id as keyof ExtendedEntry];\n if (typeof initialValue !== 'string') {\n return null;\n }\n\n const canWrite = column.columnDef.meta?.canWrite;\n if (!canWrite) {\n return <GhostedText multiline>{initialValue}</GhostedText>;\n }\n\n return <MultiLineCell initialValue={initialValue as string} handleUpdate={update} />;\n}\n\nfunction LazyImage({ row, column, table }: CellContext<ExtendedEntry, unknown>) {\n const update = useCallback(\n (newValue: string) => {\n table.options.meta?.handleUpdate(row.index, column.id, newValue, true);\n },\n [column.id, row.index, table.options.meta],\n );\n\n const event = row.original;\n if (isOntimeDelay(event)) {\n return null;\n }\n\n const canWrite = column.columnDef.meta?.canWrite;\n const initialValue = event.custom[column.id];\n return <EditableImage initialValue={initialValue} updateValue={update} readOnly={!canWrite} />;\n}\n\nfunction MakeSingleLineField({ row, column, table }: CellContext<ExtendedEntry, unknown>) {\n const update = useCallback(\n (newValue: string) => {\n table.options.meta?.handleUpdate(row.index, column.id, newValue, false);\n },\n [column.id, row.index, table.options.meta],\n );\n\n // not all entries have all properties (eg groups)\n const initialValue = row.original[column.id as keyof ExtendedEntry];\n if (typeof initialValue !== 'string') {\n return null;\n }\n\n const canWrite = column.columnDef.meta?.canWrite;\n if (!canWrite) {\n return <GhostedText>{initialValue}</GhostedText>;\n }\n\n return <SingleLineCell initialValue={initialValue as string} handleUpdate={update} />;\n}\n\nfunction MakeFlagField({ row }: CellContext<ExtendedEntry, unknown>) {\n const event = row.original;\n if (!isOntimeEvent(event) || !event.flag) {\n return null;\n }\n return <FlagCell />;\n}\n\nfunction MakeCustomField({ row, column, table }: CellContext<ExtendedEntry, unknown>) {\n const update = useCallback(\n (newValue: string) => {\n table.options.meta?.handleUpdate(row.index, column.id, newValue, true);\n },\n [column.id, row.index, table.options.meta],\n );\n\n const event = row.original;\n if (isOntimeDelay(event)) {\n return null;\n }\n\n // entries will not contain the field if there is no value set by the user\n // event if there is no initial value, we still render the cell\n const initialValue = event.custom[column.id] ?? '';\n\n const canWrite = column.columnDef.meta?.canWrite;\n if (!canWrite) {\n return <GhostedText multiline>{initialValue}</GhostedText>;\n }\n\n return <MultiLineCell initialValue={initialValue} handleUpdate={update} />;\n}\n\n/**\n * we cant use the createColumnHelper() because we have custom logic for rendering the cells\n * This means that the display columns: index and action are added inline by the row components\n */\nexport function makeCuesheetColumns(\n customFields: CustomFields,\n cuesheetMode: AppMode,\n preset: URLPreset | undefined,\n): ColumnDef<ExtendedEntry>[] {\n const columnsDef: ColumnDef<ExtendedEntry>[] = [];\n const modeAllowsWrite = cuesheetMode === AppMode.Edit;\n const fullRead = preset ? preset.options?.read === 'full' : true;\n const fullWrite = preset ? preset.options?.write === 'full' : true;\n const canWriteKeys = preset?.options?.write ? new Set(preset.options.write.split(',')) : new Set<string>();\n const canReadKeys = preset?.options?.read ? new Set(preset.options.read.split(',')) : new Set<string>();\n\n // helpers to check read/write for a given key\n const canRead = (key: string) => fullRead || canReadKeys.has(key);\n const canWrite = (key: string) => modeAllowsWrite && (fullWrite || canWriteKeys.has(key));\n\n if (canRead('flag')) {\n columnsDef.push({\n accessorKey: 'flag',\n id: 'flag',\n header: 'Flag',\n cell: MakeFlagField,\n size: 45,\n minSize: 45,\n meta: { canWrite: canWrite('flag') },\n });\n }\n\n if (canRead('cue')) {\n columnsDef.push({\n accessorKey: 'cue',\n id: 'cue',\n header: 'Cue',\n cell: MakeSingleLineField,\n size: 75,\n minSize: 40,\n meta: { canWrite: canWrite('cue') },\n });\n }\n\n if (canRead('timeStart')) {\n columnsDef.push({\n accessorKey: 'timeStart',\n id: 'timeStart',\n header: 'Start',\n cell: MakeStart,\n size: 75,\n minSize: 75,\n meta: { canWrite: canWrite('timeStart') },\n });\n }\n\n if (canRead('timeEnd')) {\n columnsDef.push({\n accessorKey: 'timeEnd',\n id: 'timeEnd',\n header: 'End',\n cell: MakeEnd,\n size: 75,\n minSize: 75,\n meta: { canWrite: canWrite('timeEnd') },\n });\n }\n\n if (canRead('duration')) {\n columnsDef.push({\n accessorKey: 'duration',\n id: 'duration',\n header: 'Duration',\n cell: MakeDuration,\n size: 75,\n minSize: 75,\n meta: { canWrite: canWrite('duration') },\n });\n }\n\n if (canRead('title')) {\n columnsDef.push({\n accessorKey: 'title',\n id: 'title',\n header: 'Title',\n cell: MakeSingleLineField,\n size: 250,\n minSize: 75,\n meta: { canWrite: canWrite('title') },\n });\n }\n\n if (canRead('note')) {\n columnsDef.push({\n accessorKey: 'note',\n id: 'note',\n header: 'Note',\n cell: MakeMultiLineField,\n size: 250,\n minSize: 75,\n meta: { canWrite: canWrite('note') },\n });\n }\n\n // custom fields at the end\n const customFieldKeys = Object.keys(customFields);\n\n for (let i = 0; i < customFieldKeys.length; i++) {\n const key = customFieldKeys[i];\n const permissionKey = `custom-${key}`;\n if (!canRead(permissionKey)) continue;\n columnsDef.push({\n accessorKey: key,\n id: key,\n header: customFields[key].label,\n cell: customFields[key].type === 'text' ? MakeCustomField : LazyImage,\n size: 250,\n minSize: 75,\n meta: {\n colour: customFields[key].colour,\n canWrite: canWrite(permissionKey),\n },\n });\n }\n\n return columnsDef;\n}\n","import EmptyImage from '../../../assets/images/empty.svg?react';\n\nimport style from './EmptyTableBody.module.scss';\n\ninterface EmptyTableBodyProps {\n text: string;\n}\n\nexport default function EmptyTableBody({ text }: EmptyTableBodyProps) {\n return (\n <tbody className={style.emptyContainer}>\n <tr>\n <td colSpan={99} className={style.emptyCell}>\n <EmptyImage className={style.empty} />\n {text && <span className={style.text}>{text}</span>}\n </td>\n </tr>\n </tbody>\n );\n}\n","import { CSSProperties, ReactNode } from 'react';\nimport { useSortable } from '@dnd-kit/sortable';\nimport { CSS } from '@dnd-kit/utilities';\nimport { Header } from '@tanstack/react-table';\n\nimport type { ExtendedEntry } from '../../../../common/utils/rundownMetadata';\n\nimport style from '../CuesheetTable.module.scss';\n\ninterface SortableCellProps {\n columnId: string;\n colSpan: number;\n injectedStyles: CSSProperties;\n children: ReactNode;\n draggable: ReactNode;\n}\n\nexport function SortableCell({ columnId, colSpan, injectedStyles, children, draggable }: SortableCellProps) {\n const { attributes, listeners, setNodeRef, transform, transition, isDragging } = useSortable({\n id: columnId,\n });\n\n // build drag styles\n const dragStyle = {\n ...injectedStyles,\n zIndex: isDragging ? 2 : 'inherit',\n transform: CSS.Translate.toString(transform),\n transition,\n };\n\n return (\n <th ref={setNodeRef} style={dragStyle} colSpan={colSpan} tabIndex={-1}>\n <div {...attributes} {...listeners}>\n {children}\n </div>\n {draggable}\n </th>\n );\n}\n\nexport function TableCell({ colSpan, injectedStyles, children, draggable }: SortableCellProps) {\n return (\n <th style={injectedStyles} colSpan={colSpan} tabIndex={-1}>\n <div>{children}</div>\n {draggable}\n </th>\n );\n}\n\ninterface DraggableProps {\n header: Header<ExtendedEntry, unknown>;\n}\n\nexport function Draggable({ header }: DraggableProps) {\n return (\n <div\n onDoubleClick={() => header.column.resetSize()}\n onMouseDown={header.getResizeHandler()}\n onTouchStart={header.getResizeHandler()}\n className={style.resizer}\n />\n );\n}\n","import { CSSProperties } from 'react';\nimport { horizontalListSortingStrategy, SortableContext } from '@dnd-kit/sortable';\nimport { flexRender, HeaderGroup } from '@tanstack/react-table';\n\nimport type { ExtendedEntry } from '../../../../common/utils/rundownMetadata';\nimport { getAccessibleColour } from '../../../../common/utils/styleUtils';\nimport { AppMode } from '../../../../ontimeConfig';\nimport { usePersistedCuesheetOptions } from '../../cuesheet.options';\n\nimport { Draggable, SortableCell, TableCell } from './SortableCell';\n\nimport style from '../CuesheetTable.module.scss';\n\ninterface CuesheetHeaderProps {\n headerGroup: HeaderGroup<ExtendedEntry>;\n cuesheetMode: AppMode;\n}\n\nexport function SortableCuesheetHeader({ headerGroup, cuesheetMode }: CuesheetHeaderProps) {\n const hideIndexColumn = usePersistedCuesheetOptions((state) => state.hideIndexColumn);\n\n return (\n <tr key={headerGroup.id}>\n {cuesheetMode === AppMode.Edit && <th className={style.actionColumn} tabIndex={-1} />}\n {!hideIndexColumn && (\n <th className={style.indexColumn} tabIndex={-1}>\n #\n </th>\n )}\n <SortableContext key={headerGroup.id} items={headerGroup.headers} strategy={horizontalListSortingStrategy}>\n {headerGroup.headers.map((header) => {\n const customBackground = header.column.columnDef.meta?.colour;\n const canWrite = header.column.columnDef.meta?.canWrite;\n\n const customStyles: CSSProperties = {\n opacity: canWrite ? 1 : 0.6,\n };\n if (customBackground) {\n const customColour = getAccessibleColour(customBackground);\n customStyles.backgroundColor = customColour.backgroundColor;\n customStyles.color = customColour.color;\n }\n\n return (\n <SortableCell\n key={header.column.columnDef.id}\n columnId={header.column.id}\n colSpan={header.colSpan}\n injectedStyles={{ width: `calc(var(--header-${header?.id}-size) * 1px)`, ...customStyles }}\n draggable={<Draggable header={header} />}\n >\n {header.isPlaceholder ? null : flexRender(header.column.columnDef.header, header.getContext())}\n </SortableCell>\n );\n })}\n </SortableContext>\n </tr>\n );\n}\n\nexport function CuesheetHeader({ headerGroup, cuesheetMode }: CuesheetHeaderProps) {\n const hideIndexColumn = usePersistedCuesheetOptions((state) => state.hideIndexColumn);\n\n return (\n <tr key={headerGroup.id}>\n {cuesheetMode === AppMode.Edit && <th className={style.actionColumn} tabIndex={-1} />}\n {!hideIndexColumn && (\n <th className={style.indexColumn} tabIndex={-1}>\n #\n </th>\n )}\n {headerGroup.headers.map((header) => {\n const customBackground = header.column.columnDef.meta?.colour;\n const canWrite = header.column.columnDef.meta?.canWrite;\n\n const customStyles: CSSProperties = {\n opacity: canWrite ? 1 : 0.6,\n };\n if (customBackground) {\n const customColour = getAccessibleColour(customBackground);\n customStyles.backgroundColor = customColour.backgroundColor;\n customStyles.color = customColour.color;\n }\n\n return (\n <TableCell\n key={header.column.columnDef.id}\n columnId={header.column.id}\n colSpan={header.colSpan}\n injectedStyles={{ width: `calc(var(--header-${header?.id}-size) * 1px)`, ...customStyles }}\n draggable={<Draggable header={header} />}\n >\n {header.isPlaceholder ? null : flexRender(header.column.columnDef.header, header.getContext())}\n </TableCell>\n );\n })}\n </tr>\n );\n}\n","import { CSSProperties, memo } from 'react';\n\nimport { millisToDelayString } from '../../../../common/utils/dateConfig';\nimport { usePersistedCuesheetOptions } from '../../cuesheet.options';\n\nimport style from './DelayRow.module.scss';\n\ninterface DelayRowProps {\n duration: number;\n injectedStyles?: CSSProperties;\n}\n\nfunction DelayRow({ duration, injectedStyles, ...virtuosoProps }: DelayRowProps) {\n const hideDelays = usePersistedCuesheetOptions((state) => state.hideDelays);\n\n if (hideDelays || duration === 0) {\n return null;\n }\n\n const delayTime = millisToDelayString(duration, 'expanded');\n\n return (\n <tr className={style.delayRow} data-testid='cuesheet-delay' style={injectedStyles} {...virtuosoProps}>\n <td tabIndex={0}>{delayTime}</td>\n </tr>\n );\n}\n\nexport default memo(DelayRow);\n","import { EntryId, SupportedEntry } from 'ontime-types';\nimport { create } from 'zustand';\n\ntype Anchor = { x: number; y: number };\n\ntype OpenMenu = {\n isOpen: true;\n entryId: EntryId;\n entryType: SupportedEntry;\n entryIndex: number;\n parentId: EntryId | null;\n flag: boolean | null;\n};\n\ntype ClosedMenu = {\n isOpen: false;\n entryId: null;\n entryType: null;\n entryIndex: null;\n parentId: null;\n flag: null;\n};\n\ntype CuesheetTableMenuStore = (OpenMenu | ClosedMenu) & {\n position: Anchor;\n openMenu: (\n position: Anchor,\n entryId: EntryId,\n entryType: SupportedEntry,\n entryIndex: number,\n parentId: EntryId | null,\n flag: boolean | null,\n ) => void;\n closeMenu: () => void;\n};\n\nexport const useCuesheetTableMenu = create<CuesheetTableMenuStore>((set) => ({\n isOpen: false,\n entryId: null,\n entryType: null,\n entryIndex: null,\n parentId: null,\n position: { x: 0, y: 0 },\n flag: null,\n openMenu: (\n position: Anchor,\n entryId: EntryId,\n entryType: SupportedEntry,\n entryIndex: number,\n parentId: EntryId | null,\n flag: null | boolean,\n ) => set({ isOpen: true, position, entryId, entryType, entryIndex, parentId, flag }),\n closeMenu: () => set({ isOpen: false }),\n}));\n","import { CSSProperties, useMemo } from 'react';\nimport { IoEllipsisHorizontal } from 'react-icons/io5';\nimport { flexRender, Table } from '@tanstack/react-table';\nimport { EntryId, OntimeEntry, RGBColour, SupportedEntry } from 'ontime-types';\nimport { colourToHex, cssOrHexToColour } from 'ontime-utils';\n\nimport IconButton from '../../../../common/components/buttons/IconButton';\nimport type { ExtendedEntry } from '../../../../common/utils/rundownMetadata';\nimport { cx, getAccessibleColour } from '../../../../common/utils/styleUtils';\nimport { AppMode } from '../../../../ontimeConfig';\nimport { useCuesheetTableMenu } from '../cuesheet-table-menu/useCuesheetTableMenu';\n\nimport style from './EventRow.module.scss';\n\ninterface EventRowProps {\n rowId: string;\n id: EntryId;\n eventIndex: number;\n colour: string;\n isFirstAfterGroup: boolean;\n isLoaded: boolean;\n isPast: boolean;\n groupColour: string | undefined;\n flag: boolean;\n skip: boolean;\n parent: EntryId | null;\n rowIndex: number;\n table: Table<ExtendedEntry<OntimeEntry>>;\n injectedStyles?: CSSProperties;\n}\n\nexport default function EventRow({\n rowId,\n id,\n eventIndex,\n colour,\n isFirstAfterGroup,\n isLoaded,\n isPast,\n groupColour,\n flag,\n skip,\n parent,\n rowIndex,\n table,\n injectedStyles,\n ...virtuosoProps\n}: EventRowProps) {\n const { cuesheetMode, hideIndexColumn } = table.options.meta?.options ?? {\n cuesheetMode: AppMode.Edit,\n hideIndexColumn: false,\n };\n\n const openMenu = useCuesheetTableMenu((store) => store.openMenu);\n\n const { color, backgroundColor } = getAccessibleColour(colour);\n const tmpColour = cssOrHexToColour(color) as RGBColour; // we know this to be a correct colour\n const mutedText = colourToHex({ ...tmpColour, alpha: tmpColour.alpha * 0.8 });\n\n const rowBgColour: string | undefined = useMemo(() => {\n if (isLoaded) {\n return '#087A27'; // $active-green\n } else if (colour) {\n // the colour is user defined and might be invalid\n const accessibleBackgroundColor = cssOrHexToColour(getAccessibleColour(colour).backgroundColor);\n if (accessibleBackgroundColor !== null) {\n return colourToHex({\n ...accessibleBackgroundColor,\n alpha: accessibleBackgroundColor.alpha * 0.25,\n });\n }\n }\n return;\n }, [colour, isLoaded]);\n\n return (\n <tr\n id={rowId}\n className={cx([\n style.eventRow,\n skip && style.skip,\n isFirstAfterGroup && style.firstAfterGroup,\n parent && style.hasParent,\n ])}\n style={{\n ...injectedStyles,\n opacity: `${isPast ? '0.2' : '1'}`,\n '--user-bg': groupColour ?? 'transparent',\n }}\n data-testid='cuesheet-event'\n {...virtuosoProps}\n >\n {cuesheetMode === AppMode.Edit && (\n <td className={style.actionColumn} tabIndex={-1} role='cell'>\n <IconButton\n aria-label='Options'\n variant='ghosted-white'\n size='small'\n onClick={(e) => {\n const rect = e.currentTarget.getBoundingClientRect();\n const yPos = 8 + rect.y + rect.height / 2;\n openMenu({ x: rect.x, y: yPos }, id, SupportedEntry.Event, rowIndex, parent, flag);\n }}\n >\n <IoEllipsisHorizontal />\n </IconButton>\n </td>\n )}\n {!hideIndexColumn && (\n <td className={style.indexColumn} style={{ backgroundColor, color: mutedText }} tabIndex={-1} role='cell'>\n {eventIndex}\n </td>\n )}\n {table\n .getRow(rowId)\n .getVisibleCells()\n .map((cell) => {\n return (\n <td\n key={cell.id}\n style={{\n width: `calc(var(--col-${cell.column.id}-size) * 1px)`,\n backgroundColor: rowBgColour,\n }}\n tabIndex={-1}\n role='cell'\n >\n {flexRender(cell.column.columnDef.cell, cell.getContext())}\n </td>\n );\n })}\n </tr>\n );\n}\n","import { CSSProperties } from 'react';\nimport { IoEllipsisHorizontal } from 'react-icons/io5';\nimport { flexRender, Table } from '@tanstack/react-table';\nimport { EntryId, SupportedEntry } from 'ontime-types';\n\nimport IconButton from '../../../../common/components/buttons/IconButton';\nimport type { ExtendedEntry } from '../../../../common/utils/rundownMetadata';\nimport { AppMode } from '../../../../ontimeConfig';\nimport { useCuesheetTableMenu } from '../cuesheet-table-menu/useCuesheetTableMenu';\n\nimport style from './GroupRow.module.scss';\n\ninterface GroupRowProps {\n groupId: EntryId;\n colour: string;\n rowId: string;\n rowIndex: number;\n table: Table<ExtendedEntry>;\n injectedStyles?: CSSProperties;\n}\n\nexport default function GroupRow({\n groupId,\n colour,\n rowId,\n rowIndex,\n table,\n injectedStyles,\n ...virtuosoProps\n}: GroupRowProps) {\n const { cuesheetMode, hideIndexColumn } = table.options.meta?.options ?? {\n cuesheetMode: AppMode.Edit,\n hideIndexColumn: false,\n };\n\n const openMenu = useCuesheetTableMenu((store) => store.openMenu);\n\n return (\n <tr\n className={style.groupRow}\n style={{ ...injectedStyles, '--user-bg': colour }}\n data-testid='cuesheet-group'\n {...virtuosoProps}\n >\n {cuesheetMode === AppMode.Edit && (\n <td className={style.actionColumn} tabIndex={-1} role='cell'>\n <IconButton\n aria-label='Options'\n variant='ghosted-white'\n size='small'\n onClick={(e) => {\n const rect = e.currentTarget.getBoundingClientRect();\n const yPos = 8 + rect.y + rect.height / 2;\n openMenu({ x: rect.x, y: yPos }, groupId, SupportedEntry.Group, rowIndex, null, null);\n }}\n >\n <IoEllipsisHorizontal />\n </IconButton>\n </td>\n )}\n {!hideIndexColumn && <td className={style.indexColumn} tabIndex={-1} role='cell' />}\n {table\n .getRow(rowId)\n .getVisibleCells()\n .map((cell) => {\n return (\n <td\n key={cell.id}\n tabIndex={-1}\n style={{\n width: `calc(var(--col-${cell.column.id}-size) * 1px)`,\n }}\n role='cell'\n >\n {flexRender(cell.column.columnDef.cell, cell.getContext())}\n </td>\n );\n })}\n </tr>\n );\n}\n","import { CSSProperties } from 'react';\nimport { IoEllipsisHorizontal } from 'react-icons/io5';\nimport { flexRender, Table } from '@tanstack/react-table';\nimport { EntryId, SupportedEntry } from 'ontime-types';\nimport { colourToHex, cssOrHexToColour } from 'ontime-utils';\n\nimport IconButton from '../../../../common/components/buttons/IconButton';\nimport type { ExtendedEntry } from '../../../../common/utils/rundownMetadata';\nimport { cx, enDash, getAccessibleColour } from '../../../../common/utils/styleUtils';\nimport { AppMode } from '../../../../ontimeConfig';\nimport { useCuesheetTableMenu } from '../cuesheet-table-menu/useCuesheetTableMenu';\n\nimport style from './MilestoneRow.module.scss';\n\ninterface MilestoneRowProps {\n entryId: EntryId;\n isPast: boolean;\n parentBgColour?: string;\n parentId: EntryId | null;\n colour: string;\n rowId: string;\n rowIndex: number;\n table: Table<ExtendedEntry>;\n injectedStyles?: CSSProperties;\n}\n\nexport default function MilestoneRow({\n entryId,\n isPast,\n parentBgColour,\n parentId,\n colour,\n rowId,\n rowIndex,\n table,\n injectedStyles,\n ...virtuosoProps\n}: MilestoneRowProps) {\n const { cuesheetMode, hideIndexColumn } = table.options.meta?.options ?? {\n cuesheetMode: AppMode.Edit,\n hideIndexColumn: false,\n };\n\n const openMenu = useCuesheetTableMenu((store) => store.openMenu);\n\n let rowBgColour: string | undefined;\n if (colour) {\n // the colour is user defined and might be invalid\n const accessibleBackgroundColor = cssOrHexToColour(getAccessibleColour(colour).backgroundColor);\n if (accessibleBackgroundColor !== null) {\n rowBgColour = colourToHex({\n ...accessibleBackgroundColor,\n alpha: accessibleBackgroundColor.alpha * 0.25,\n });\n }\n }\n\n return (\n <tr\n className={cx([style.milestoneRow, Boolean(parentBgColour) && style.hasParent])}\n style={{\n ...injectedStyles,\n opacity: `${isPast ? '0.2' : '1'}`,\n '--user-bg': parentBgColour ?? 'transparent',\n }}\n data-testid='cuesheet-milestone'\n {...virtuosoProps}\n >\n {cuesheetMode === AppMode.Edit && (\n <td className={style.actionColumn} tabIndex={-1} role='cell'>\n <IconButton\n aria-label='Options'\n variant='ghosted-white'\n size='small'\n onClick={(e) => {\n const rect = e.currentTarget.getBoundingClientRect();\n const yPos = 8 + rect.y + rect.height / 2;\n openMenu({ x: rect.x, y: yPos }, entryId, SupportedEntry.Milestone, rowIndex, parentId, null);\n }}\n >\n <IoEllipsisHorizontal />\n </IconButton>\n </td>\n )}\n {!hideIndexColumn && (\n <td className={style.indexColumn} tabIndex={-1} role='cell'>\n {enDash}\n </td>\n )}\n {table\n .getRow(rowId)\n .getVisibleCells()\n .map((cell) => {\n const canRender =\n cell.column.id !== 'duration' && cell.column.id !== 'timeStart' && cell.column.id !== 'timeEnd';\n return (\n <td\n key={cell.id}\n style={{\n width: `calc(var(--col-${cell.column.id}-size) * 1px)`,\n backgroundColor: rowBgColour,\n opacity: canRender ? 1 : 0.4,\n }}\n tabIndex={-1}\n >\n {canRender && flexRender(cell.column.columnDef.cell, cell.getContext())}\n </td>\n );\n })}\n </tr>\n );\n}\n","import { create } from 'zustand';\n\ninterface CuesheetPermissionsStore {\n canChangeMode: boolean;\n canCreateEntries: boolean;\n canEditEntries: boolean;\n canFlag: boolean;\n canShare: boolean;\n setPermissions: (permissions: Omit<CuesheetPermissionsStore, 'setPermissions'>) => void;\n}\n\nexport const useCuesheetPermissions = create<CuesheetPermissionsStore>((set) => ({\n canChangeMode: false,\n canCreateEntries: false,\n canEditEntries: false,\n canFlag: false,\n canShare: false,\n setPermissions(permissions) {\n set({\n canChangeMode: permissions.canChangeMode,\n canFlag: permissions.canFlag,\n canCreateEntries: permissions.canCreateEntries,\n canEditEntries: permissions.canEditEntries,\n canShare: permissions.canShare,\n });\n },\n}));\n","import { memo } from 'react';\nimport { IoAdd, IoArrowDown, IoArrowUp, IoDuplicateOutline, IoOptions, IoTrash } from 'react-icons/io5';\nimport { SupportedEntry } from 'ontime-types';\n\nimport { PositionedDropdownMenu } from '../../../../common/components/dropdown-menu/DropdownMenu';\nimport { useEntryActions } from '../../../../common/hooks/useEntryAction';\nimport { useCuesheetEditModal } from '../../cuesheet-edit-modal/useCuesheetEditModal';\nimport { useCuesheetPermissions } from '../../useTablePermissions';\n\nimport { useCuesheetTableMenu } from './useCuesheetTableMenu';\n\nexport default memo(CuesheetTableMenu);\n\nfunction CuesheetTableMenu() {\n const { isOpen, entryId, entryIndex, parentId, flag, position, closeMenu } = useCuesheetTableMenu();\n const { addEntry, clone, deleteEntry, move, updateEntry } = useEntryActions();\n const showModal = useCuesheetEditModal((state) => state.setEditableEntry);\n const permissions = useCuesheetPermissions();\n\n if (!isOpen) {\n return null;\n }\n\n return (\n <PositionedDropdownMenu\n isOpen\n onClose={closeMenu}\n items={[\n {\n type: 'item',\n label: 'Edit...',\n onClick: () => showModal(entryId),\n icon: IoOptions,\n disabled: !permissions.canEditEntries,\n },\n { type: 'divider' },\n {\n type: 'item',\n label: flag ? 'Remove flag' : 'Add flag',\n onClick: () => updateEntry({ id: entryId, flag: !flag }),\n icon: IoDuplicateOutline,\n disabled: flag === null || !permissions.canFlag,\n },\n { type: 'divider' },\n {\n type: 'item',\n label: 'Add event above',\n onClick: () => addEntry({ type: SupportedEntry.Event, parent: parentId }, { before: entryId }),\n icon: IoAdd,\n disabled: !permissions.canCreateEntries,\n },\n {\n type: 'item',\n label: 'Add event below',\n onClick: () => addEntry({ type: SupportedEntry.Event, parent: parentId }, { after: entryId }),\n icon: IoAdd,\n disabled: !permissions.canCreateEntries,\n },\n {\n type: 'item',\n label: 'Clone event',\n onClick: () => clone(entryId),\n icon: IoDuplicateOutline,\n disabled: !permissions.canCreateEntries,\n },\n { type: 'divider' },\n {\n type: 'item',\n label: 'Move up',\n onClick: () => move(entryId, 'up'),\n icon: IoArrowUp,\n disabled: entryIndex < 1 || !permissions.canEditEntries,\n },\n {\n type: 'item',\n label: 'Move down',\n onClick: () => move(entryId, 'down'),\n icon: IoArrowDown,\n disabled: !permissions.canEditEntries,\n },\n { type: 'divider' },\n {\n type: 'item',\n label: 'Delete',\n onClick: () => deleteEntry([entryId]),\n icon: IoTrash,\n disabled: !permissions.canEditEntries,\n },\n ]}\n position={position}\n />\n );\n}\n","import { IconBaseProps } from 'react-icons';\nimport { IoLink } from 'react-icons/io5';\n\nexport default function RotatedLink(linkProps: IconBaseProps) {\n return <IoLink style={{ transform: 'rotate(-45deg)' }} {...linkProps} />;\n}\n","import { Toolbar } from '@base-ui-components/react/toolbar';\nimport { useDisclosure } from '@mantine/hooks';\nimport { OntimeView } from 'ontime-types';\n\nimport Button from '../../../../common/components/buttons/Button';\nimport RotatedLink from '../../../../common/components/icons/RotatedLink';\nimport Modal from '../../../../common/components/modal/Modal';\nimport useInfo from '../../../../common/hooks-query/useInfo';\nimport useUrlPresets from '../../../../common/hooks-query/useUrlPresets';\nimport GenerateLinkFormExport from '../../../../features/sharing/GenerateLinkFormExport';\n\nfunction CuesheetShareModal() {\n const { data: infoData } = useInfo();\n const { data: urlPresetData } = useUrlPresets();\n const [isOpen, handler] = useDisclosure();\n\n // Don't render the modal content until it's open and data is loaded\n const showModalContent = isOpen && infoData && urlPresetData;\n\n return (\n <>\n <Toolbar.Button onClick={handler.open} render={<Button />}>\n <RotatedLink />\n Share...\n </Toolbar.Button>\n <Modal\n isOpen={isOpen}\n onClose={handler.close}\n title='Share cuesheet view'\n showBackdrop\n showCloseButton\n bodyElements={\n showModalContent ? (\n <GenerateLinkFormExport lockedPath={{ value: OntimeView.Cuesheet, label: 'Cuesheet' }} />\n ) : null\n }\n />\n </>\n );\n}\n\nexport default CuesheetShareModal;\n","import { ReactNode, use } from 'react';\nimport { IoChevronDown, IoOptions, IoSettingsOutline } from 'react-icons/io5';\nimport { Popover } from '@base-ui-components/react/popover';\nimport { Toggle } from '@base-ui-components/react/toggle';\nimport { ToggleGroup } from '@base-ui-components/react/toggle-group';\nimport { Toolbar } from '@base-ui-components/react/toolbar';\nimport { useSessionStorage } from '@mantine/hooks';\nimport type { Column } from '@tanstack/react-table';\n\nimport Button from '../../../../common/components/buttons/Button';\nimport Checkbox from '../../../../common/components/checkbox/Checkbox';\nimport * as Editor from '../../../../common/components/editor-utils/EditorUtils';\nimport PopoverContents from '../../../../common/components/popover/Popover';\nimport { PresetContext } from '../../../../common/context/PresetContext';\nimport type { ExtendedEntry } from '../../../../common/utils/rundownMetadata';\nimport { cx } from '../../../../common/utils/styleUtils';\nimport { AppMode, sessionKeys } from '../../../../ontimeConfig';\nimport { usePersistedCuesheetOptions } from '../../cuesheet.options';\nimport { useCuesheetPermissions } from '../../useTablePermissions';\n\nimport CuesheetShareModal from './CuesheetShareModal';\n\nimport style from './CuesheetTableSettings.module.scss';\n\ninterface CuesheetTableSettingsProps {\n columns: Column<ExtendedEntry, unknown>[];\n handleResetResizing: () => void;\n handleResetReordering: () => void;\n handleClearToggles: () => void;\n}\n\nexport default function CuesheetTableSettings({\n columns,\n handleResetResizing,\n handleResetReordering,\n handleClearToggles,\n}: CuesheetTableSettingsProps) {\n const canShare = useCuesheetPermissions((state) => state.canShare);\n const preset = use(PresetContext);\n\n const [cuesheetMode, setCuesheetMode] = useSessionStorage({\n key: preset ? `${preset.alias}${sessionKeys.cuesheetMode}` : sessionKeys.cuesheetMode,\n defaultValue: preset ? AppMode.Run : AppMode.Edit,\n });\n\n const toggleCuesheetMode = (mode: AppMode[]) => {\n // we need to stop user from deselecting a mode\n const newValue = mode.at(0);\n if (!newValue) return;\n setCuesheetMode(newValue);\n };\n\n return (\n <Toolbar.Root className={style.tableSettings}>\n <ViewSettings />\n <ColumnSettings\n columns={columns}\n handleResetResizing={handleResetResizing}\n handleResetReordering={handleResetReordering}\n handleClearToggles={handleClearToggles}\n />\n <ToggleGroup value={[cuesheetMode]} onValueChange={toggleCuesheetMode} className={cx([style.group, style.apart])}>\n <Toolbar.Button render={<Toggle />} value={AppMode.Run} className={style.radioButton}>\n Run\n </Toolbar.Button>\n <Toolbar.Button render={<Toggle />} value={AppMode.Edit} className={style.radioButton}>\n Edit\n </Toolbar.Button>\n </ToggleGroup>\n\n {canShare && (\n <>\n <Editor.Separator orientation='vertical' />\n <CuesheetShareModal />\n </>\n )}\n </Toolbar.Root>\n );\n}\n\nfunction ViewSettings() {\n const options = usePersistedCuesheetOptions();\n\n return (\n <Popover.Root>\n <Popover.Trigger\n render={\n <Toolbar.Button\n render={\n <Button variant='ghosted-white'>\n <IoSettingsOutline /> Settings\n <IoChevronDown />\n </Button>\n }\n />\n }\n />\n\n <PopoverContents align='start' className={style.inline}>\n <div className={style.column}>\n <Editor.Label className={style.sectionTitle}>Element visibility</Editor.Label>\n <Editor.Label className={style.option}>\n <Checkbox\n defaultChecked={options.hideTableSeconds}\n onCheckedChange={(checked) => options.setOption('hideTableSeconds', checked)}\n />\n Hide seconds in table\n </Editor.Label>\n <Editor.Label className={style.option}>\n <Checkbox\n defaultChecked={options.hideIndexColumn}\n onCheckedChange={(checked) => options.setOption('hideIndexColumn', checked)}\n />\n Hide index column\n </Editor.Label>\n </div>\n\n <div className={style.column}>\n <Editor.Label className={style.sectionTitle}>Table Behaviour</Editor.Label>\n <Editor.Label className={style.option}>\n <Checkbox\n defaultChecked={options.showDelayedTimes}\n onCheckedChange={(checked) => options.setOption('showDelayedTimes', checked)}\n />\n Show delayed times\n </Editor.Label>\n <Editor.Label className={style.option}>\n <Checkbox\n defaultChecked={options.hideDelays}\n onCheckedChange={(checked) => options.setOption('hideDelays', checked)}\n />\n Hide delay entries\n </Editor.Label>\n </div>\n </PopoverContents>\n </Popover.Root>\n );\n}\n\nfunction ColumnSettings({\n columns,\n handleResetResizing,\n handleResetReordering,\n handleClearToggles,\n}: CuesheetTableSettingsProps) {\n return (\n <Popover.Root>\n <Popover.Trigger\n render={\n <Toolbar.Button\n render={\n <Button variant='ghosted-white'>\n <IoOptions /> View\n <IoChevronDown />\n </Button>\n }\n />\n }\n />\n <PopoverContents align='start' className={style.inline}>\n <div className={style.column}>\n <Editor.Label className={style.sectionTitle}>Column visibility</Editor.Label>\n {columns.map((column) => {\n const columnHeader = column.columnDef.header;\n const visible = column.getIsVisible();\n return (\n <Editor.Label key={`${column.id}-${visible}`} className={style.option}>\n <Checkbox defaultChecked={visible} onCheckedChange={column.toggleVisibility} />\n {columnHeader as ReactNode}\n </Editor.Label>\n );\n })}\n </div>\n <Editor.Separator orientation='vertical' />\n <div className={style.column}>\n <Editor.Label className={style.sectionTitle}>Reset Options</Editor.Label>\n <Button size='small' fluid onClick={handleClearToggles}>\n Show All\n </Button>\n <Button size='small' fluid onClick={handleResetResizing}>\n Reset Resizing\n </Button>\n <Button size='small' fluid onClick={handleResetReordering}>\n Reset Reordering\n </Button>\n </div>\n </PopoverContents>\n </Popover.Root>\n );\n}\n","import { useCallback, useEffect, useMemo, useRef } from 'react';\nimport { TableVirtuoso, TableVirtuosoHandle } from 'react-virtuoso';\nimport { useTableNav } from '@table-nav/react';\nimport { ColumnDef, getCoreRowModel, useReactTable } from '@tanstack/react-table';\nimport { isOntimeDelay, isOntimeGroup, isOntimeMilestone, OntimeEntry, TimeField } from 'ontime-types';\n\nimport EmptyPage from '../../../common/components/state/EmptyPage';\nimport EmptyTableBody from '../../../common/components/state/EmptyTableBody';\nimport { useEntryActions } from '../../../common/hooks/useEntryAction';\nimport { useSelectedEventId } from '../../../common/hooks/useSocket';\nimport { useFlatRundownWithMetadata } from '../../../common/hooks-query/useRundown';\nimport type { ExtendedEntry } from '../../../common/utils/rundownMetadata';\nimport { AppMode } from '../../../ontimeConfig';\nimport { usePersistedCuesheetOptions } from '../cuesheet.options';\n\nimport { CuesheetHeader, SortableCuesheetHeader } from './cuesheet-table-elements/CuesheetHeader';\nimport DelayRow from './cuesheet-table-elements/DelayRow';\nimport EventRow from './cuesheet-table-elements/EventRow';\nimport GroupRow from './cuesheet-table-elements/GroupRow';\nimport MilestoneRow from './cuesheet-table-elements/MilestoneRow';\nimport CuesheetTableMenu from './cuesheet-table-menu/CuesheetTableMenu';\nimport CuesheetTableSettings from './cuesheet-table-settings/CuesheetTableSettings';\nimport { useColumnOrder, useColumnSizes, useColumnVisibility } from './useColumnManager';\n\nimport style from './CuesheetTable.module.scss';\n\ninterface CuesheetTableProps {\n columns: ColumnDef<ExtendedEntry>[];\n cuesheetMode: AppMode;\n}\n\nexport default function CuesheetTable({ columns, cuesheetMode }: CuesheetTableProps) {\n const { data, status } = useFlatRundownWithMetadata();\n const { updateEntry, updateTimer } = useEntryActions();\n const showDelayedTimes = usePersistedCuesheetOptions((state) => state.showDelayedTimes);\n const hideTableSeconds = usePersistedCuesheetOptions((state) => state.hideTableSeconds);\n const hideIndexColumn = usePersistedCuesheetOptions((state) => state.hideIndexColumn);\n\n const { selectedEventId } = useSelectedEventId();\n\n const virtuosoRef = useRef<TableVirtuosoHandle | null>(null);\n const { listeners } = useTableNav();\n\n const meta = useMemo(\n () => ({\n handleUpdate: (rowIndex: number, accessor: string, payload: string, isCustom = false) => {\n // check if value is the same\n const event = data[rowIndex];\n\n if (!event) {\n return;\n }\n\n // skip if there is no value change\n const key = accessor as keyof OntimeEntry;\n const previousValue = event[key];\n if (previousValue === payload) {\n return;\n }\n\n if (isCustom) {\n updateEntry({ id: event.id, custom: { [accessor]: payload } });\n return;\n }\n\n updateEntry({ id: event.id, [accessor]: payload });\n },\n handleUpdateTimer: (eventId: string, field: TimeField, payload: string) => {\n // the timer element already contains logic to avoid submitting a unchanged value\n updateTimer(eventId, field, payload, true);\n },\n options: {\n showDelayedTimes,\n hideTableSeconds,\n cuesheetMode,\n hideIndexColumn,\n },\n }),\n [cuesheetMode, data, hideIndexColumn, hideTableSeconds, showDelayedTimes, updateEntry, updateTimer],\n );\n\n const { columnOrder, resetColumnOrder } = useColumnOrder(columns);\n const { columnSizing, setColumnSizing } = useColumnSizes();\n const { columnVisibility, setColumnVisibility } = useColumnVisibility();\n\n const table = useReactTable({\n data,\n columns,\n columnResizeMode: 'onChange',\n state: {\n columnOrder,\n columnVisibility,\n columnSizing,\n },\n onColumnVisibilityChange: setColumnVisibility,\n onColumnSizingChange: setColumnSizing,\n getCoreRowModel: getCoreRowModel(),\n meta,\n });\n\n const setAllVisible = useCallback(() => {\n table.toggleAllColumnsVisible(true);\n }, [table]);\n\n const resetColumnResizing = useCallback(() => {\n setColumnSizing({});\n }, [setColumnSizing]);\n\n // in run mode, we follow the selected row\n useEffect(() => {\n if (cuesheetMode === AppMode.Edit || virtuosoRef.current === null || !selectedEventId) {\n return;\n }\n\n const eventIndex = data.findIndex((event) => event.id === selectedEventId);\n virtuosoRef.current.scrollToIndex({ index: eventIndex, behavior: 'smooth' });\n }, [cuesheetMode, data, selectedEventId]);\n\n /**\n * To improve performance on resizing, we memoise the column sizes\n * and pass them as CSS variables to the table container.\n */\n const columnSizeVars = useMemo(() => {\n const headers = table.getFlatHeaders();\n const colSizes: { [key: string]: number } = {};\n for (let i = 0; i < headers.length; i++) {\n const header = headers[i];\n if (!header) continue;\n colSizes[`--header-${header.id}-size`] = header.getSize();\n colSizes[`--col-${header.column.id}-size`] = header.column.getSize();\n }\n return colSizes;\n // eslint-disable-next-line react-compiler/react-compiler -- unfortunately this is what we need\n // eslint-disable-next-line react-hooks/exhaustive-deps -- this works well and follows documentation\n }, [table.getState().columnSizingInfo, table.getState().columnSizing]);\n\n const allLeafColumns = table.getAllLeafColumns();\n const { rows } = table.getRowModel();\n\n const isLoading = !data || status === 'pending';\n\n if (isLoading) {\n return <EmptyPage text='Loading...' />;\n }\n\n return (\n <>\n <CuesheetTableSettings\n columns={allLeafColumns}\n handleResetResizing={resetColumnResizing}\n handleResetReordering={resetColumnOrder}\n handleClearToggles={setAllVisible}\n />\n <TableVirtuoso\n ref={virtuosoRef}\n data={data}\n increaseViewportBy={{ top: 100, bottom: 200 }}\n components={{\n EmptyPlaceholder: () => <EmptyTableBody text='No data in rundown' />,\n Table: ({ style: injectedStyles, ...virtuosoProps }) => {\n return (\n <table\n className={style.cuesheet}\n id='cuesheet'\n style={{ ...injectedStyles, ...columnSizeVars }}\n {...listeners}\n {...virtuosoProps}\n />\n );\n },\n TableRow: ({ item: _item, style: injectedStyles, ...virtuosoProps }) => {\n // eslint-disable-next-line react/destructuring-assignment\n const rowIndex = virtuosoProps['data-index'];\n const row = rows[rowIndex];\n const key = row.original.id;\n const entry = row.original;\n\n if (isOntimeGroup(entry)) {\n return (\n <GroupRow\n key={key}\n groupId={entry.id}\n colour={entry.colour}\n rowId={row.id}\n rowIndex={row.index}\n table={table}\n injectedStyles={injectedStyles}\n {...virtuosoProps}\n />\n );\n }\n\n if (isOntimeDelay(entry)) {\n return (\n <DelayRow key={key} duration={entry.duration} injectedStyles={injectedStyles} {...virtuosoProps} />\n );\n }\n\n if (isOntimeMilestone(entry)) {\n return (\n <MilestoneRow\n key={key}\n entryId={entry.id}\n isPast={entry.isPast}\n parentBgColour={entry.groupColour}\n parentId={entry.parent}\n colour={entry.colour}\n rowId={row.id}\n rowIndex={rowIndex}\n table={table}\n injectedStyles={injectedStyles}\n {...virtuosoProps}\n />\n );\n }\n\n return (\n <EventRow\n key={row.id}\n id={entry.id}\n eventIndex={entry.eventIndex}\n colour={entry.colour}\n isFirstAfterGroup={entry.isFirstAfterGroup}\n isLoaded={entry.isLoaded}\n isPast={entry.isPast}\n groupColour={entry.groupColour}\n flag={entry.flag}\n skip={entry.skip}\n parent={entry.parent}\n rowId={row.id}\n rowIndex={rowIndex}\n table={table}\n injectedStyles={injectedStyles}\n {...virtuosoProps}\n />\n );\n },\n TableHead: (virtuosoProps) => <thead className={style.tableHeader} {...virtuosoProps} />,\n }}\n fixedHeaderContent={() => {\n return table.getHeaderGroups().map((headerGroup) => {\n const HeaderComponent = table.getState().columnSizingInfo.isResizingColumn\n ? CuesheetHeader\n : SortableCuesheetHeader;\n\n // if the table is being resized, we render non-sortable headers to avoid performance issues\n return <HeaderComponent key={headerGroup.id} cuesheetMode={cuesheetMode} headerGroup={headerGroup} />;\n });\n }}\n />\n\n <CuesheetTableMenu />\n </>\n );\n}\n","import { memo, use, useEffect, useMemo } from 'react';\nimport { useSessionStorage } from '@mantine/hooks';\n\nimport EmptyPage from '../../common/components/state/EmptyPage';\nimport { PresetContext } from '../../common/context/PresetContext';\nimport useCustomFields from '../../common/hooks-query/useCustomFields';\nimport { sessionScope } from '../../externals';\nimport { AppMode, sessionKeys } from '../../ontimeConfig';\n\nimport CuesheetDnd from './cuesheet-dnd/CuesheetDnd';\nimport { makeCuesheetColumns } from './cuesheet-table/cuesheet-table-elements/cuesheetColsFactory';\nimport CuesheetTable from './cuesheet-table/CuesheetTable';\nimport { useCuesheetPermissions } from './useTablePermissions';\n\nexport default memo(CuesheetTableWrapper);\nfunction CuesheetTableWrapper() {\n const { data: customFields, status: customFieldStatus } = useCustomFields();\n const setPermissions = useCuesheetPermissions((state) => state.setPermissions);\n const preset = use(PresetContext);\n\n // set permissions based on preset\n useEffect(() => {\n if (preset) {\n const fullWrite = preset.options?.write === 'full';\n setPermissions({\n canChangeMode: preset.options?.write !== '-',\n canCreateEntries: fullWrite,\n canEditEntries: fullWrite,\n canFlag: fullWrite || Boolean(preset.options?.write.includes('flag')),\n canShare: false, // TODO: should be sessionScope === 'rw' when we have granular scopes\n });\n } else {\n setPermissions({\n canChangeMode: true,\n canCreateEntries: true,\n canEditEntries: true,\n canFlag: true,\n canShare: sessionScope === 'rw',\n });\n }\n }, [preset, setPermissions]);\n\n const [cuesheetMode] = useSessionStorage({\n key: preset ? `${preset.alias}${sessionKeys.cuesheetMode}` : sessionKeys.cuesheetMode,\n defaultValue: preset ? AppMode.Run : AppMode.Edit,\n });\n\n const columns = useMemo(\n () => makeCuesheetColumns(customFields, cuesheetMode, preset),\n [customFields, cuesheetMode, preset],\n );\n\n const isLoading = !customFields || customFieldStatus === 'pending';\n\n return (\n <CuesheetDnd columns={columns}>\n {isLoading ? <EmptyPage text='Loading...' /> : <CuesheetTable columns={columns} cuesheetMode={cuesheetMode} />}\n </CuesheetDnd>\n );\n}\n","import { IoApps } from 'react-icons/io5';\nimport { useDisclosure } from '@mantine/hooks';\n\nimport IconButton from '../../common/components/buttons/IconButton';\nimport NavigationMenu from '../../common/components/navigation-menu/NavigationMenu';\nimport { useWindowTitle } from '../../common/hooks/useWindowTitle';\nimport { getIsNavigationLocked } from '../../externals';\nimport CuesheetOverview from '../../features/overview/CuesheetOverview';\n\nimport CuesheetEditModal from './cuesheet-edit-modal/CuesheetEditModal';\nimport CuesheetProgress from './cuesheet-progress/CuesheetProgress';\nimport CuesheetTableWrapper from './CuesheetTableWrapper';\n\nimport styles from './CuesheetPage.module.scss';\n\nexport default function CuesheetPage() {\n const [isMenuOpen, menuHandler] = useDisclosure();\n\n useWindowTitle('Cuesheet');\n\n const isLocked = getIsNavigationLocked();\n\n return (\n <>\n <NavigationMenu isOpen={isMenuOpen} onClose={menuHandler.close} />\n <CuesheetEditModal />\n <div className={styles.tableWrapper} data-testid='cuesheet'>\n <CuesheetOverview>\n {!isLocked && (\n <IconButton aria-label='Toggle navigation' variant='subtle-white' size='xlarge' onClick={menuHandler.open}>\n <IoApps />\n </IconButton>\n )}\n </CuesheetOverview>\n <CuesheetProgress />\n <CuesheetTableWrapper />\n </div>\n </>\n );\n}\n","import ProtectRoute from '../../common/components/protect-route/ProtectRoute';\n\nimport CuesheetPage from './CuesheetPage';\n\nexport default function ProtectedCuesheet() {\n return (\n <ProtectRoute permission='operator'>\n <CuesheetPage />\n </ProtectRoute>\n );\n}\n"],"names":["useIsMobileScreen","width","useViewportSize","useMemo","memo","CuesheetOverview","children","jsx","CuesheetMobile","CuesheetDesktop","jsxs","OverviewWrapper","TimerOverview","OffsetOverview","TitleOverview","StartTimes","MetadataTimes","ClockOverview","CuesheetEntryEditor","entryId","data","useRundown","entry","setEntry","useState","useEffect","event","isOntimeEvent","style","EventEditor","isOntimeMilestone","MilestoneEditor","isOntimeGroup","GroupEditor","useCuesheetEditModal","create","set","CuesheetEditModal","state","closeModal","Modal","CuesheetProgress","useViewSettings","current","duration","timeWarning","timeDanger","useProgressData","MultiPartProgressBar","styles","debounce","callback","wait","timeout","args","tableSizesKey","makeStageKey","tableHiddenKey","tableOrderKey","saveSizesToStorage","sizes","useColumnSizes","columnSizing","setColumnSizingState","stored","setColumnSizing","useCallback","sizesOrUpdater","useColumnOrder","columns","columnOrder","saveColumnOrder","useLocalStorage","col","newColumns","id","resetColumnOrder","useColumnVisibility","columnVisibility","setColumnVisibility","CuesheetDnd","sensors","useSensors","useSensor","PointerSensor","TouchSensor","handleOnDragEnd","delta","active","over","fromIndex","toIndex","reorderedCols","reorderedItem","DndContext","closestCorners","SingleLineCell","forwardRef","initialValue","allowSubmitSameValue","handleUpdate","handleCancelUpdate","inputRef","ref","useRef","submitCallback","newValue","value","onChange","onBlur","onKeyDown","useReactiveTextInput","useImperativeHandle","_a","_b","Input","DurationInput","lockedValue","delayed","onSubmit","isEditing","setIsEditing","setValue","textRef","handleFakeFocus","handleFakeBlur","valueInMillis","parseUserTime","_c","timeString","millisToString","TextLikeInput","EditableImage","readOnly","updateValue","openInNewTab","Button","FlagCell","TbFlagFilled","GhostedText","multiline","MultiLineCell","AutoTextarea","MutedText","numeric","cx","TimeInputDuration","formatTime","MakeStart","getValue","row","table","column","showDelayedTimes","hideTableSeconds","formatOpts","handleUpdateTimer","update","startTime","isStartLocked","displayTime","formattedTime","TimeInput","DelayIndicator","MakeEnd","endTime","isEndLocked","TimeStrategy","MakeDuration","isDurationLocked","formattedDuration","formatDuration","MakeMultiLineField","LazyImage","isOntimeDelay","canWrite","MakeSingleLineField","MakeFlagField","MakeCustomField","makeCuesheetColumns","customFields","cuesheetMode","preset","columnsDef","modeAllowsWrite","AppMode","fullRead","fullWrite","canWriteKeys","canReadKeys","_d","canRead","key","customFieldKeys","i","permissionKey","EmptyTableBody","text","EmptyImage","SortableCell","columnId","colSpan","injectedStyles","draggable","attributes","listeners","setNodeRef","transform","transition","isDragging","useSortable","dragStyle","CSS","TableCell","Draggable","header","SortableCuesheetHeader","headerGroup","hideIndexColumn","usePersistedCuesheetOptions","SortableContext","horizontalListSortingStrategy","customBackground","customStyles","customColour","getAccessibleColour","flexRender","CuesheetHeader","DelayRow","virtuosoProps","delayTime","millisToDelayString","useCuesheetTableMenu","position","entryType","entryIndex","parentId","flag","EventRow","rowId","eventIndex","colour","isFirstAfterGroup","isLoaded","isPast","groupColour","skip","parent","rowIndex","openMenu","store","color","backgroundColor","tmpColour","cssOrHexToColour","mutedText","colourToHex","rowBgColour","accessibleBackgroundColor","IconButton","e","rect","yPos","SupportedEntry","IoEllipsisHorizontal","cell","GroupRow","groupId","MilestoneRow","parentBgColour","enDash","canRender","useCuesheetPermissions","permissions","CuesheetTableMenu","isOpen","closeMenu","addEntry","clone","deleteEntry","move","updateEntry","useEntryActions","showModal","PositionedDropdownMenu","IoOptions","IoDuplicateOutline","IoAdd","IoArrowUp","IoArrowDown","IoTrash","RotatedLink","linkProps","IoLink","CuesheetShareModal","infoData","useInfo","urlPresetData","useUrlPresets","handler","useDisclosure","showModalContent","Fragment","Toolbar.Button","GenerateLinkFormExport","OntimeView","CuesheetTableSettings","handleResetResizing","handleResetReordering","handleClearToggles","canShare","use","PresetContext","setCuesheetMode","useSessionStorage","sessionKeys","toggleCuesheetMode","mode","Toolbar.Root","ViewSettings","ColumnSettings","ToggleGroup","Toggle","Editor.Separator","options","Popover.Root","Popover.Trigger","IoSettingsOutline","IoChevronDown","PopoverContents","Editor.Label","Checkbox","checked","columnHeader","visible","CuesheetTable","status","useFlatRundownWithMetadata","updateTimer","selectedEventId","useSelectedEventId","virtuosoRef","useTableNav","meta","accessor","payload","isCustom","eventId","field","useReactTable","getCoreRowModel","setAllVisible","resetColumnResizing","columnSizeVars","headers","colSizes","allLeafColumns","rows","EmptyPage","TableVirtuoso","_item","HeaderComponent","CuesheetTableWrapper","customFieldStatus","useCustomFields","setPermissions","sessionScope","isLoading","CuesheetPage","isMenuOpen","menuHandler","useWindowTitle","isLocked","getIsNavigationLocked","NavigationMenu","IoApps","ProtectedCuesheet","ProtectRoute"],"mappings":"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"}
1
+ {"version":3,"file":"ProtectedCuesheet-DvYSgueA.js","sources":["../../src/common/hooks/useIsMobileScreen.ts","../../src/features/overview/CuesheetOverview.tsx","../../src/features/rundown/entry-editor/CuesheetEventEditor.tsx","../../src/views/cuesheet/cuesheet-edit-modal/useCuesheetEditModal.tsx","../../src/views/cuesheet/cuesheet-edit-modal/CuesheetEditModal.tsx","../../src/views/cuesheet/cuesheet-progress/CuesheetProgress.tsx","../../src/common/utils/debounce.ts","../../src/views/cuesheet/cuesheet-table/useColumnManager.tsx","../../src/views/cuesheet/cuesheet-dnd/CuesheetDnd.tsx","../../src/views/cuesheet/cuesheet-table/cuesheet-table-elements/SingleLineCell.tsx","../../src/views/cuesheet/cuesheet-table/cuesheet-table-elements/DurationInput.tsx","../../src/views/cuesheet/cuesheet-table/cuesheet-table-elements/EditableImage.tsx","../../src/views/cuesheet/cuesheet-table/cuesheet-table-elements/FlagCell.tsx","../../src/views/cuesheet/cuesheet-table/cuesheet-table-elements/GhostedText.tsx","../../src/views/cuesheet/cuesheet-table/cuesheet-table-elements/MultiLineCell.tsx","../../src/views/cuesheet/cuesheet-table/cuesheet-table-elements/MutedText.tsx","../../src/views/cuesheet/cuesheet-table/cuesheet-table-elements/TimeInput.tsx","../../src/views/cuesheet/cuesheet-table/cuesheet-table-elements/cuesheetColsFactory.tsx","../../src/common/components/state/EmptyTableBody.tsx","../../src/views/cuesheet/cuesheet-table/cuesheet-table-elements/SortableCell.tsx","../../src/views/cuesheet/cuesheet-table/cuesheet-table-elements/CuesheetHeader.tsx","../../src/views/cuesheet/cuesheet-table/cuesheet-table-elements/DelayRow.tsx","../../src/views/cuesheet/cuesheet-table/cuesheet-table-menu/useCuesheetTableMenu.tsx","../../src/views/cuesheet/cuesheet-table/cuesheet-table-elements/EventRow.tsx","../../src/views/cuesheet/cuesheet-table/cuesheet-table-elements/GroupRow.tsx","../../src/views/cuesheet/cuesheet-table/cuesheet-table-elements/MilestoneRow.tsx","../../src/views/cuesheet/useTablePermissions.tsx","../../src/views/cuesheet/cuesheet-table/cuesheet-table-menu/CuesheetTableMenu.tsx","../../src/common/components/icons/RotatedLink.tsx","../../src/views/cuesheet/cuesheet-table/cuesheet-table-settings/CuesheetShareModal.tsx","../../src/views/cuesheet/cuesheet-table/cuesheet-table-settings/CuesheetTableSettings.tsx","../../src/views/cuesheet/cuesheet-table/CuesheetTable.tsx","../../src/views/cuesheet/CuesheetTableWrapper.tsx","../../src/views/cuesheet/CuesheetPage.tsx","../../src/views/cuesheet/ProtectedCuesheet.tsx"],"sourcesContent":["import { useMemo } from 'react';\nimport { useViewportSize } from '@mantine/hooks';\n\nexport function useIsMobileScreen(): boolean {\n const { width } = useViewportSize();\n\n return useMemo(() => width < 800, [width]);\n}\n","import { memo, PropsWithChildren } from 'react';\n\nimport { useIsMobileScreen } from '../../common/hooks/useIsMobileScreen';\n\nimport { ClockOverview, MetadataTimes, OffsetOverview, StartTimes, TimerOverview } from './composite/TimeElements';\nimport TitleOverview from './composite/TitleOverview';\nimport { OverviewWrapper } from './OverviewWrapper';\n\nexport default memo(CuesheetOverview);\nfunction CuesheetOverview({ children }: PropsWithChildren) {\n const isMobileScreen = useIsMobileScreen();\n\n if (isMobileScreen) return <CuesheetMobile>{children}</CuesheetMobile>;\n else return <CuesheetDesktop>{children}</CuesheetDesktop>;\n}\n\nfunction CuesheetMobile({ children }: PropsWithChildren) {\n return (\n <OverviewWrapper navElements={children}>\n <TimerOverview />\n <OffsetOverview />\n </OverviewWrapper>\n );\n}\n\nfunction CuesheetDesktop({ children }: PropsWithChildren) {\n return (\n <OverviewWrapper navElements={children}>\n <TitleOverview />\n <StartTimes shouldFormat />\n <TimerOverview />\n <OffsetOverview />\n <MetadataTimes />\n <ClockOverview shouldFormat />\n </OverviewWrapper>\n );\n}\n","import { useEffect, useState } from 'react';\nimport { isOntimeEvent, isOntimeGroup, isOntimeMilestone, OntimeEntry } from 'ontime-types';\n\nimport useRundown from '../../../common/hooks-query/useRundown';\n\nimport EventEditor from './EventEditor';\nimport GroupEditor from './GroupEditor';\nimport MilestoneEditor from './MilestoneEditor';\n\nimport style from './EntryEditor.module.scss';\n\ninterface CuesheetEntryEditorProps {\n entryId: string;\n}\n\nexport default function CuesheetEntryEditor({ entryId }: CuesheetEntryEditorProps) {\n const { data } = useRundown();\n const [entry, setEntry] = useState<OntimeEntry | null>(null);\n\n useEffect(() => {\n if (data.order.length === 0) {\n setEntry(null);\n return;\n }\n\n const event = data.entries[entryId];\n if (event) {\n setEntry(event);\n } else {\n setEntry(null);\n }\n }, [entryId, data.order, data.entries]);\n\n if (isOntimeEvent(entry)) {\n return (\n <div className={style.entryEditor} data-testid='editor-container'>\n <EventEditor event={entry} />\n </div>\n );\n }\n\n if (isOntimeMilestone(entry)) {\n return (\n <div className={style.inModal} data-testid='editor-container'>\n <MilestoneEditor milestone={entry} />\n </div>\n );\n }\n\n if (isOntimeGroup(entry)) {\n return (\n <div className={style.inModal} data-testid='editor-container'>\n <GroupEditor group={entry} />\n </div>\n );\n }\n\n return null;\n}\n","import { EntryId } from 'ontime-types';\nimport { create } from 'zustand';\n\ninterface SelectedEntryState {\n selectedEntryId: EntryId | null;\n setEditableEntry: (entryId: EntryId) => void;\n clearSelection: () => void;\n}\n\nexport const useCuesheetEditModal = create<SelectedEntryState>((set) => ({\n selectedEntryId: null,\n setEditableEntry: (entryId: EntryId) => set({ selectedEntryId: entryId }),\n clearSelection: () => set({ selectedEntryId: null }),\n}));\n","import { memo } from 'react';\n\nimport Modal from '../../../common/components/modal/Modal';\nimport CuesheetEntryEditor from '../../../features/rundown/entry-editor/CuesheetEventEditor';\n\nimport { useCuesheetEditModal } from './useCuesheetEditModal';\n\nexport default memo(CuesheetEditModal);\nfunction CuesheetEditModal() {\n const entryId = useCuesheetEditModal((state) => state.selectedEntryId);\n const closeModal = useCuesheetEditModal((state) => state.clearSelection);\n\n if (entryId === null) {\n return null;\n }\n\n return (\n <Modal\n isOpen\n onClose={closeModal}\n title='Edit entry'\n showCloseButton\n bodyElements={<CuesheetEntryEditor entryId={entryId} />}\n />\n );\n}\n","import MultiPartProgressBar from '../../../common/components/multi-part-progress-bar/MultiPartProgressBar';\nimport { useProgressData } from '../../../common/hooks/useSocket';\nimport useViewSettings from '../../../common/hooks-query/useViewSettings';\n\nimport styles from './CuesheetProgress.module.scss';\n\nexport default function CuesheetProgress() {\n const { data } = useViewSettings();\n const { current, duration, timeWarning, timeDanger } = useProgressData();\n\n return (\n <MultiPartProgressBar\n now={current}\n complete={duration}\n normalColor={data.normalColor}\n warning={timeWarning}\n warningColor={data.warningColor}\n danger={timeDanger}\n dangerColor={data.dangerColor}\n className={styles.progressOverride}\n ignoreCssOverride\n />\n );\n}\n","export function debounce<T extends any[]>(callback: (...args: T) => void, wait: number) {\n let timeout: NodeJS.Timeout | null;\n return (...args: T) => {\n if (timeout) {\n clearTimeout(timeout);\n }\n timeout = setTimeout(() => {\n timeout = null;\n callback(...args);\n }, wait);\n };\n}\n","import { useCallback, useEffect, useState } from 'react';\nimport { useLocalStorage } from '@mantine/hooks';\nimport { ColumnDef, ColumnSizingState, Updater } from '@tanstack/react-table';\n\nimport { debounce } from '../../../common/utils/debounce';\nimport { makeStageKey } from '../../../common/utils/localStorage';\nimport type { ExtendedEntry } from '../../../common/utils/rundownMetadata';\n\nconst tableSizesKey = makeStageKey('cuesheet-sizes');\nconst tableHiddenKey = makeStageKey('cuesheet-hidden');\nconst tableOrderKey = makeStageKey('cuesheet-order');\n\nconst saveSizesToStorage = debounce((sizes: Record<string, number>) => {\n localStorage.setItem(tableSizesKey, JSON.stringify(sizes));\n}, 500);\n\nexport function useColumnSizes() {\n const [columnSizing, setColumnSizingState] = useState<Record<string, number>>(() => {\n try {\n const stored = localStorage.getItem(tableSizesKey);\n return stored ? JSON.parse(stored) : {};\n } catch {\n return {};\n }\n });\n\n // save sizes to localStorage whenever they change (debounced)\n useEffect(() => {\n saveSizesToStorage(columnSizing);\n }, [columnSizing]);\n\n const setColumnSizing = useCallback((sizesOrUpdater: Updater<ColumnSizingState>) => {\n setColumnSizingState(sizesOrUpdater);\n }, []);\n\n return {\n columnSizing,\n setColumnSizing,\n };\n}\n\nexport function useColumnOrder(columns: ColumnDef<ExtendedEntry>[]) {\n const [columnOrder, saveColumnOrder] = useLocalStorage<string[]>({\n key: tableOrderKey,\n defaultValue: columns.map((col) => col.id as string),\n });\n\n // update column order if columns change\n useEffect(() => {\n const newColumns = columns.map((col) => col.id as string);\n if (newColumns.some((id) => !columnOrder.includes(id))) {\n saveColumnOrder(newColumns);\n }\n }, [columnOrder, columns, saveColumnOrder]);\n\n const resetColumnOrder = useCallback(() => {\n saveColumnOrder(columns.map((col) => col.id as string));\n }, [columns, saveColumnOrder]);\n\n return {\n columnOrder,\n saveColumnOrder,\n resetColumnOrder,\n };\n}\n\nexport function useColumnVisibility() {\n const [columnVisibility, setColumnVisibility] = useLocalStorage({\n key: tableHiddenKey,\n defaultValue: {},\n });\n\n return {\n columnVisibility,\n setColumnVisibility,\n };\n}\n","import { PropsWithChildren } from 'react';\nimport {\n closestCorners,\n DndContext,\n DragEndEvent,\n PointerSensor,\n TouchSensor,\n useSensor,\n useSensors,\n} from '@dnd-kit/core';\nimport { ColumnDef } from '@tanstack/react-table';\n\nimport type { ExtendedEntry } from '../../../common/utils/rundownMetadata';\nimport { useColumnOrder } from '../cuesheet-table/useColumnManager';\n\ninterface CuesheetDndProps {\n columns: ColumnDef<ExtendedEntry>[];\n}\n\nexport default function CuesheetDnd({ columns, children }: PropsWithChildren<CuesheetDndProps>) {\n const { columnOrder, saveColumnOrder } = useColumnOrder(columns);\n\n const sensors = useSensors(\n useSensor(PointerSensor, {\n activationConstraint: {\n delay: 100,\n tolerance: 50,\n },\n }),\n useSensor(TouchSensor, {\n activationConstraint: {\n delay: 100,\n tolerance: 50,\n },\n }),\n );\n\n const handleOnDragEnd = (event: DragEndEvent) => {\n const { delta, active, over } = event;\n\n // cancel if delta y is greater than 200\n if (delta.y > 200) return;\n // cancel if we do not have an over id\n if (over?.id == null) return;\n\n // get index of from\n const fromIndex = columnOrder.indexOf(active.id as string);\n\n // get index of to\n const toIndex = columnOrder.indexOf(over.id as string);\n\n if (toIndex === -1) {\n return;\n }\n\n const reorderedCols = [...columnOrder];\n const reorderedItem = reorderedCols.splice(fromIndex, 1);\n reorderedCols.splice(toIndex, 0, reorderedItem[0]);\n saveColumnOrder(reorderedCols);\n };\n\n return (\n <DndContext sensors={sensors} collisionDetection={closestCorners} onDragEnd={handleOnDragEnd}>\n {children}\n </DndContext>\n );\n}\n","import { forwardRef, memo, useCallback, useImperativeHandle, useRef } from 'react';\n\nimport Input from '../../../../common/components/input/input/Input';\nimport useReactiveTextInput from '../../../../common/components/input/text-input/useReactiveTextInput';\n\ninterface SingleLineCellProps {\n initialValue: string;\n allowSubmitSameValue?: boolean;\n handleUpdate: (newValue: string) => void;\n handleCancelUpdate?: () => void;\n}\n\nconst SingleLineCell = forwardRef(\n ({ initialValue, allowSubmitSameValue, handleUpdate, handleCancelUpdate }: SingleLineCellProps, inputRef) => {\n const ref = useRef<HTMLInputElement | null>(null);\n const submitCallback = useCallback((newValue: string) => handleUpdate(newValue), [handleUpdate]);\n\n const { value, onChange, onBlur, onKeyDown } = useReactiveTextInput(initialValue, submitCallback, ref, {\n allowSubmitSameValue,\n allowKeyboardNavigation: true,\n submitOnEnter: true, // single line should submit on enter\n submitOnCtrlEnter: true,\n onCancelUpdate: handleCancelUpdate,\n });\n\n // expose a subset of the methods to the parent\n useImperativeHandle(inputRef, () => {\n return {\n focus() {\n ref.current?.focus();\n },\n select() {\n ref.current?.select();\n },\n focusParentElement() {\n ref.current?.parentElement?.focus();\n },\n };\n }, [ref]);\n\n return (\n <Input\n ref={ref}\n variant='ghosted'\n fluid\n value={value}\n onChange={onChange}\n onBlur={onBlur}\n onKeyDown={onKeyDown}\n />\n );\n },\n);\n\nSingleLineCell.displayName = 'SingleLineCell';\n\nexport default memo(SingleLineCell);\n","import { memo, PropsWithChildren, useCallback, useEffect, useRef, useState } from 'react';\nimport { millisToString, parseUserTime } from 'ontime-utils';\n\nimport SingleLineCell from './SingleLineCell';\nimport TextLikeInput from './TextLikeInput';\n\ninterface DurationInputProps {\n initialValue: number;\n lockedValue: boolean;\n delayed?: boolean;\n onSubmit: (value: string) => void;\n}\n\ninterface ParentFocusableInput extends HTMLInputElement {\n focusParentElement: () => void;\n}\n\nexport default memo(DurationInput);\n\nfunction DurationInput({\n initialValue,\n lockedValue,\n delayed,\n onSubmit,\n children,\n}: PropsWithChildren<DurationInputProps>) {\n const [isEditing, setIsEditing] = useState(false);\n const [value, setValue] = useState(initialValue);\n const inputRef = useRef<ParentFocusableInput>(null);\n const textRef = useRef<ParentFocusableInput>(null);\n\n // when we go into edit mode, set focus to the input\n useEffect(() => {\n if (isEditing && inputRef.current) {\n inputRef.current.focus();\n inputRef.current.select();\n }\n }, [isEditing]);\n\n // reset value when initialValue changes, avoiding interrupting the user if we are in edit mode\n useEffect(() => {\n if (!isEditing) {\n setValue(initialValue);\n }\n }, [initialValue, isEditing]);\n\n const handleFakeFocus = () => setIsEditing(true);\n const handleFakeBlur = () => {\n setIsEditing(false);\n setTimeout(() => textRef.current?.focusParentElement()); // Immediate timeout to ensure state change takes place first\n };\n\n const handleUpdate = useCallback(\n (newValue: string) => {\n setIsEditing(false);\n\n // if the user sends an empty string, we want to clear the value\n if (newValue === '') {\n onSubmit(newValue);\n inputRef.current?.focusParentElement();\n return;\n }\n\n // we dont know the values in the rundown, escalate to handler\n if (newValue.startsWith('p') || newValue.startsWith('+')) {\n onSubmit(newValue);\n inputRef.current?.focusParentElement();\n return;\n }\n\n const valueInMillis = parseUserTime(newValue);\n if (valueInMillis < 0 || isNaN(valueInMillis)) {\n setValue(initialValue);\n setTimeout(() => textRef.current?.focusParentElement()); // Immediate timeout to ensure state change takes place first\n return;\n }\n\n // if the value is the same, we may still want to push the lock change\n if (valueInMillis === initialValue && lockedValue) {\n inputRef.current?.focusParentElement();\n return;\n }\n\n onSubmit(newValue);\n setValue(Number(newValue));\n setTimeout(() => textRef.current?.focusParentElement()); // Immediate timeout to ensure state change takes place first\n },\n [initialValue, lockedValue, onSubmit],\n );\n\n const timeString = millisToString(value);\n\n return isEditing ? (\n <SingleLineCell\n ref={inputRef}\n initialValue={timeString}\n allowSubmitSameValue={!lockedValue} // if the value is not locked, submitting will lock the value\n handleUpdate={handleUpdate}\n handleCancelUpdate={handleFakeBlur}\n />\n ) : (\n <TextLikeInput\n onClick={handleFakeFocus}\n onFocus={handleFakeFocus}\n muted={!lockedValue}\n offset={delayed ? 'over' : undefined}\n ref={textRef}\n >\n {children}\n </TextLikeInput>\n );\n}\n","import { memo } from 'react';\n\nimport Button from '../../../../common/components/buttons/Button';\nimport Input from '../../../../common/components/input/input/Input';\n\nimport style from './EditableImage.module.scss';\n\ninterface EditableImageProps {\n initialValue: string;\n readOnly?: boolean;\n updateValue: (newValue: string) => void;\n}\n\nexport default memo(EditableImage);\n\nfunction EditableImage({ initialValue, readOnly, updateValue }: EditableImageProps) {\n const handleUpdate = (newValue: string) => {\n if (newValue === initialValue) {\n return;\n }\n if (newValue !== '' && !newValue.startsWith('http')) {\n return;\n }\n updateValue(newValue);\n };\n\n const openInNewTab = () => {\n if (initialValue) {\n window.open(initialValue, '_blank', 'noopener,noreferrer');\n }\n };\n\n if (!initialValue) {\n return (\n <Input\n variant='ghosted'\n className={style.imageInput}\n fluid\n readOnly={readOnly}\n // we disable the field to prevent receiving focus\n disabled={readOnly}\n placeholder='Paste image URL'\n onBlur={(event) => handleUpdate(event.currentTarget.value)}\n onKeyDown={(event) => {\n if (event.key === 'Enter') {\n handleUpdate(event.currentTarget.value);\n }\n }}\n defaultValue={initialValue}\n />\n );\n }\n\n return (\n <div className={style.imageCell}>\n {!readOnly && (\n <div className={style.overlay}>\n <Button onClick={openInNewTab}>Preview</Button>\n <Button variant='subtle-destructive' onClick={() => handleUpdate('')}>\n Delete\n </Button>\n </div>\n )}\n {Boolean(initialValue) && <img loading='lazy' src={initialValue} className={style.image} />}\n </div>\n );\n}\n","import { TbFlagFilled } from 'react-icons/tb';\n\nimport style from './FlagCell.module.scss';\n\nexport default function FlagCell() {\n return (\n <div className={style.flag}>\n <TbFlagFilled />\n </div>\n );\n}\n","import { PropsWithChildren } from 'react';\n\nimport style from './GhostedText.module.scss';\n\ninterface GhostedTextProps {\n multiline?: boolean;\n}\n\nexport default function GhostedText({ children, multiline }: PropsWithChildren<GhostedTextProps>) {\n return <div className={`${style.ghostedText} ${multiline ? style.multiline : ''}`}>{children}</div>;\n}\n","import { memo, useCallback, useRef } from 'react';\n\nimport { AutoTextarea } from '../../../../common/components/input/auto-textarea/AutoTextarea';\nimport useReactiveTextInput from '../../../../common/components/input/text-input/useReactiveTextInput';\n\ninterface MultiLineCellProps {\n initialValue: string;\n handleUpdate: (newValue: string) => void;\n}\n\nexport default memo(MultiLineCell);\n\nfunction MultiLineCell({ initialValue, handleUpdate }: MultiLineCellProps) {\n const ref = useRef<HTMLTextAreaElement | null>(null);\n const submitCallback = useCallback((newValue: string) => handleUpdate(newValue), [handleUpdate]);\n\n const { value, onChange, onBlur, onKeyDown } = useReactiveTextInput(initialValue, submitCallback, ref, {\n submitOnCtrlEnter: true,\n allowKeyboardNavigation: true,\n });\n\n return (\n <AutoTextarea\n inputref={ref}\n variant='ghosted'\n fluid\n rows={1}\n value={value}\n onChange={onChange}\n onBlur={onBlur}\n onKeyDown={onKeyDown}\n spellCheck={false}\n />\n );\n}\n","import { PropsWithChildren } from 'react';\n\nimport { cx } from '../../../../common/utils/styleUtils';\n\nimport style from './MutedText.module.scss';\n\ninterface MutedTextProps {\n numeric?: boolean;\n}\n\nexport default function MutedText({ numeric, children }: PropsWithChildren<MutedTextProps>) {\n return <span className={cx([style.muted, numeric && style.numeric])}>{children}</span>;\n}\n","import { memo, PropsWithChildren, useCallback, useEffect, useRef, useState } from 'react';\nimport { parseUserTime } from 'ontime-utils';\n\nimport { formatTime } from '../../../../common/utils/time';\n\nimport SingleLineCell from './SingleLineCell';\nimport TextLikeInput from './TextLikeInput';\n\ninterface TimeInputDurationProps {\n initialValue: number;\n lockedValue: boolean;\n delayed?: boolean;\n onSubmit: (value: string) => void;\n}\n\ninterface ParentFocusableInput extends HTMLInputElement {\n focusParentElement: () => void;\n}\n\nexport default memo(TimeInputDuration);\n\nfunction TimeInputDuration({\n initialValue,\n lockedValue,\n delayed,\n onSubmit,\n children,\n}: PropsWithChildren<TimeInputDurationProps>) {\n const [isEditing, setIsEditing] = useState(false);\n const [value, setValue] = useState(initialValue);\n const inputRef = useRef<ParentFocusableInput>(null);\n const textRef = useRef<ParentFocusableInput>(null);\n\n // when we go into edit mode, set focus to the input\n useEffect(() => {\n if (isEditing && inputRef.current) {\n inputRef.current.focus();\n inputRef.current.select();\n }\n }, [isEditing]);\n\n // reset value when initialValue changes, avoiding interrupting the user if we are in edit mode\n useEffect(() => {\n if (!isEditing) {\n setValue(initialValue);\n }\n }, [initialValue, isEditing]);\n\n const handleFakeFocus = () => setIsEditing(true);\n const handleFakeBlur = () => {\n setIsEditing(false);\n setTimeout(() => textRef.current?.focusParentElement()); // Immediate timeout to ensure state change takes place first\n };\n\n const handleUpdate = useCallback(\n (newValue: string) => {\n setIsEditing(false);\n\n // if the user sends an empty string, we want to clear the value\n if (newValue === '') {\n onSubmit(newValue);\n inputRef.current?.focusParentElement();\n return;\n }\n\n // we dont know the values in the rundown, escalate to handler\n if (newValue.startsWith('p') || newValue.startsWith('+')) {\n onSubmit(newValue);\n inputRef.current?.focusParentElement();\n return;\n }\n\n const valueInMillis = parseUserTime(newValue);\n if (valueInMillis < 0 || isNaN(valueInMillis)) {\n setValue(initialValue);\n setTimeout(() => textRef.current?.focusParentElement()); // Immediate timeout to ensure state change takes place first\n return;\n }\n\n // if the value is the same, we may still want to push the lock change\n if (valueInMillis === initialValue && lockedValue) {\n inputRef.current?.focusParentElement();\n return;\n }\n\n onSubmit(newValue);\n setValue(Number(newValue));\n setTimeout(() => textRef.current?.focusParentElement()); // Immediate timeout to ensure state change takes place first\n },\n [initialValue, lockedValue, onSubmit],\n );\n\n const timeString = formatTime(value);\n\n return isEditing ? (\n <SingleLineCell\n ref={inputRef}\n initialValue={timeString}\n allowSubmitSameValue={!lockedValue} // if the value is not locked, submitting will lock the value\n handleUpdate={handleUpdate}\n handleCancelUpdate={handleFakeBlur}\n />\n ) : (\n <TextLikeInput\n onClick={handleFakeFocus}\n onFocus={handleFakeFocus}\n muted={!lockedValue}\n offset={delayed ? 'over' : undefined}\n ref={textRef}\n >\n {children}\n </TextLikeInput>\n );\n}\n","import { useCallback } from 'react';\nimport { CellContext, ColumnDef } from '@tanstack/react-table';\nimport { CustomFields, isOntimeDelay, isOntimeEvent, TimeStrategy, URLPreset } from 'ontime-types';\nimport { millisToString } from 'ontime-utils';\n\nimport DelayIndicator from '../../../../common/components/delay-indicator/DelayIndicator';\nimport type { ExtendedEntry } from '../../../../common/utils/rundownMetadata';\nimport { formatDuration, formatTime } from '../../../../common/utils/time';\nimport { AppMode } from '../../../../ontimeConfig';\n\nimport DurationInput from './DurationInput';\nimport EditableImage from './EditableImage';\nimport FlagCell from './FlagCell';\nimport GhostedText from './GhostedText';\nimport MultiLineCell from './MultiLineCell';\nimport MutedText from './MutedText';\nimport SingleLineCell from './SingleLineCell';\nimport TimeInput from './TimeInput';\n\nfunction MakeStart({ getValue, row, table, column }: CellContext<ExtendedEntry, unknown>) {\n if (!table.options.meta) {\n return null;\n }\n\n const { showDelayedTimes, hideTableSeconds } = table.options.meta.options;\n const formatOpts = hideTableSeconds ? { format12: 'h:mm a', format24: 'HH:mm' } : undefined;\n\n const event = row.original;\n if (!isOntimeEvent(event)) {\n return <MutedText numeric>{formatTime(getValue() as number, formatOpts)}</MutedText>;\n }\n\n const { handleUpdateTimer } = table.options.meta;\n\n const update = (newValue: string) => handleUpdateTimer(row.original.id, 'timeStart', newValue);\n\n const startTime = getValue() as number;\n const isStartLocked = !event.linkStart;\n const displayTime = showDelayedTimes ? startTime + event.delay : startTime;\n const formattedTime = formatTime(displayTime, formatOpts);\n\n const canWrite = column.columnDef.meta?.canWrite;\n if (!canWrite) {\n return (\n <MutedText numeric>\n {formattedTime}\n <DelayIndicator delayValue={event.delay} tooltipPrefix={millisToString(startTime)} />\n </MutedText>\n );\n }\n return (\n <TimeInput initialValue={startTime} onSubmit={update} lockedValue={isStartLocked} delayed={event.delay !== 0}>\n {formattedTime}\n <DelayIndicator delayValue={event.delay} tooltipPrefix={millisToString(startTime)} />\n </TimeInput>\n );\n}\n\nfunction MakeEnd({ getValue, row, table, column }: CellContext<ExtendedEntry, unknown>) {\n if (!table.options.meta) {\n return null;\n }\n\n const { showDelayedTimes, hideTableSeconds } = table.options.meta.options;\n const formatOpts = hideTableSeconds ? { format12: 'h:mm a', format24: 'HH:mm' } : undefined;\n\n const event = row.original;\n if (!isOntimeEvent(event)) {\n return <MutedText numeric>{formatTime(getValue() as number, formatOpts)}</MutedText>;\n }\n\n const { handleUpdateTimer } = table.options.meta;\n\n const update = (newValue: string) => handleUpdateTimer(row.original.id, 'timeEnd', newValue);\n\n const endTime = getValue() as number;\n const isEndLocked = event.timeStrategy === TimeStrategy.LockEnd;\n const displayTime = showDelayedTimes ? endTime + event.delay : endTime;\n const formattedTime = formatTime(displayTime, formatOpts);\n\n const canWrite = column.columnDef.meta?.canWrite;\n if (!canWrite) {\n return (\n <MutedText numeric>\n {formattedTime}\n <DelayIndicator delayValue={event.delay} tooltipPrefix={millisToString(endTime)} />\n </MutedText>\n );\n }\n\n return (\n <TimeInput initialValue={endTime} onSubmit={update} lockedValue={isEndLocked} delayed={event.delay !== 0}>\n {formattedTime}\n <DelayIndicator delayValue={event.delay} tooltipPrefix={millisToString(endTime)} />\n </TimeInput>\n );\n}\n\nfunction MakeDuration({ getValue, row, table, column }: CellContext<ExtendedEntry, unknown>) {\n if (!table.options.meta) {\n return null;\n }\n\n const { hideTableSeconds } = table.options.meta.options;\n const event = row.original;\n if (!isOntimeEvent(event)) {\n return <MutedText numeric>{formatDuration(getValue() as number, hideTableSeconds)}</MutedText>;\n }\n\n const { handleUpdateTimer } = table.options.meta;\n\n const update = (newValue: string) => handleUpdateTimer(row.original.id, 'duration', newValue);\n\n const duration = getValue() as number;\n const isDurationLocked = event.timeStrategy === TimeStrategy.LockDuration;\n const formattedDuration = formatDuration(duration, hideTableSeconds);\n\n const canWrite = column.columnDef.meta?.canWrite;\n if (!canWrite) {\n return <MutedText numeric>{formattedDuration}</MutedText>;\n }\n\n return (\n <DurationInput initialValue={duration} onSubmit={update} lockedValue={isDurationLocked}>\n {formattedDuration}\n </DurationInput>\n );\n}\n\nfunction MakeMultiLineField({ row, column, table }: CellContext<ExtendedEntry, unknown>) {\n const update = useCallback(\n (newValue: string) => {\n table.options.meta?.handleUpdate(row.index, column.id, newValue, false);\n },\n [column.id, row.index, table.options.meta],\n );\n\n // not all entries have all properties (eg groups)\n const initialValue = row.original[column.id as keyof ExtendedEntry];\n if (typeof initialValue !== 'string') {\n return null;\n }\n\n const canWrite = column.columnDef.meta?.canWrite;\n if (!canWrite) {\n return <GhostedText multiline>{initialValue}</GhostedText>;\n }\n\n return <MultiLineCell initialValue={initialValue as string} handleUpdate={update} />;\n}\n\nfunction LazyImage({ row, column, table }: CellContext<ExtendedEntry, unknown>) {\n const update = useCallback(\n (newValue: string) => {\n table.options.meta?.handleUpdate(row.index, column.id, newValue, true);\n },\n [column.id, row.index, table.options.meta],\n );\n\n const event = row.original;\n if (isOntimeDelay(event)) {\n return null;\n }\n\n const canWrite = column.columnDef.meta?.canWrite;\n const initialValue = event.custom[column.id];\n return <EditableImage initialValue={initialValue} updateValue={update} readOnly={!canWrite} />;\n}\n\nfunction MakeSingleLineField({ row, column, table }: CellContext<ExtendedEntry, unknown>) {\n const update = useCallback(\n (newValue: string) => {\n table.options.meta?.handleUpdate(row.index, column.id, newValue, false);\n },\n [column.id, row.index, table.options.meta],\n );\n\n // not all entries have all properties (eg groups)\n const initialValue = row.original[column.id as keyof ExtendedEntry];\n if (typeof initialValue !== 'string') {\n return null;\n }\n\n const canWrite = column.columnDef.meta?.canWrite;\n if (!canWrite) {\n return <GhostedText>{initialValue}</GhostedText>;\n }\n\n return <SingleLineCell initialValue={initialValue as string} handleUpdate={update} />;\n}\n\nfunction MakeFlagField({ row }: CellContext<ExtendedEntry, unknown>) {\n const event = row.original;\n if (!isOntimeEvent(event) || !event.flag) {\n return null;\n }\n return <FlagCell />;\n}\n\nfunction MakeCustomField({ row, column, table }: CellContext<ExtendedEntry, unknown>) {\n const update = useCallback(\n (newValue: string) => {\n table.options.meta?.handleUpdate(row.index, column.id, newValue, true);\n },\n [column.id, row.index, table.options.meta],\n );\n\n const event = row.original;\n if (isOntimeDelay(event)) {\n return null;\n }\n\n // entries will not contain the field if there is no value set by the user\n // event if there is no initial value, we still render the cell\n const initialValue = event.custom[column.id] ?? '';\n\n const canWrite = column.columnDef.meta?.canWrite;\n if (!canWrite) {\n return <GhostedText multiline>{initialValue}</GhostedText>;\n }\n\n return <MultiLineCell initialValue={initialValue} handleUpdate={update} />;\n}\n\n/**\n * we cant use the createColumnHelper() because we have custom logic for rendering the cells\n * This means that the display columns: index and action are added inline by the row components\n */\nexport function makeCuesheetColumns(\n customFields: CustomFields,\n cuesheetMode: AppMode,\n preset: URLPreset | undefined,\n): ColumnDef<ExtendedEntry>[] {\n const columnsDef: ColumnDef<ExtendedEntry>[] = [];\n const modeAllowsWrite = cuesheetMode === AppMode.Edit;\n const fullRead = preset ? preset.options?.read === 'full' : true;\n const fullWrite = preset ? preset.options?.write === 'full' : true;\n const canWriteKeys = preset?.options?.write ? new Set(preset.options.write.split(',')) : new Set<string>();\n const canReadKeys = preset?.options?.read ? new Set(preset.options.read.split(',')) : new Set<string>();\n\n // helpers to check read/write for a given key\n const canRead = (key: string) => fullRead || canReadKeys.has(key);\n const canWrite = (key: string) => modeAllowsWrite && (fullWrite || canWriteKeys.has(key));\n\n if (canRead('flag')) {\n columnsDef.push({\n accessorKey: 'flag',\n id: 'flag',\n header: 'Flag',\n cell: MakeFlagField,\n size: 45,\n minSize: 45,\n meta: { canWrite: canWrite('flag') },\n });\n }\n\n if (canRead('cue')) {\n columnsDef.push({\n accessorKey: 'cue',\n id: 'cue',\n header: 'Cue',\n cell: MakeSingleLineField,\n size: 75,\n minSize: 40,\n meta: { canWrite: canWrite('cue') },\n });\n }\n\n if (canRead('timeStart')) {\n columnsDef.push({\n accessorKey: 'timeStart',\n id: 'timeStart',\n header: 'Start',\n cell: MakeStart,\n size: 75,\n minSize: 75,\n meta: { canWrite: canWrite('timeStart') },\n });\n }\n\n if (canRead('timeEnd')) {\n columnsDef.push({\n accessorKey: 'timeEnd',\n id: 'timeEnd',\n header: 'End',\n cell: MakeEnd,\n size: 75,\n minSize: 75,\n meta: { canWrite: canWrite('timeEnd') },\n });\n }\n\n if (canRead('duration')) {\n columnsDef.push({\n accessorKey: 'duration',\n id: 'duration',\n header: 'Duration',\n cell: MakeDuration,\n size: 75,\n minSize: 75,\n meta: { canWrite: canWrite('duration') },\n });\n }\n\n if (canRead('title')) {\n columnsDef.push({\n accessorKey: 'title',\n id: 'title',\n header: 'Title',\n cell: MakeSingleLineField,\n size: 250,\n minSize: 75,\n meta: { canWrite: canWrite('title') },\n });\n }\n\n if (canRead('note')) {\n columnsDef.push({\n accessorKey: 'note',\n id: 'note',\n header: 'Note',\n cell: MakeMultiLineField,\n size: 250,\n minSize: 75,\n meta: { canWrite: canWrite('note') },\n });\n }\n\n // custom fields at the end\n const customFieldKeys = Object.keys(customFields);\n\n for (let i = 0; i < customFieldKeys.length; i++) {\n const key = customFieldKeys[i];\n const permissionKey = `custom-${key}`;\n if (!canRead(permissionKey)) continue;\n columnsDef.push({\n accessorKey: key,\n id: key,\n header: customFields[key].label,\n cell: customFields[key].type === 'text' ? MakeCustomField : LazyImage,\n size: 250,\n minSize: 75,\n meta: {\n colour: customFields[key].colour,\n canWrite: canWrite(permissionKey),\n },\n });\n }\n\n return columnsDef;\n}\n","import EmptyImage from '../../../assets/images/empty.svg?react';\n\nimport style from './EmptyTableBody.module.scss';\n\ninterface EmptyTableBodyProps {\n text: string;\n}\n\nexport default function EmptyTableBody({ text }: EmptyTableBodyProps) {\n return (\n <tbody className={style.emptyContainer}>\n <tr>\n <td colSpan={99} className={style.emptyCell}>\n <EmptyImage className={style.empty} />\n {text && <span className={style.text}>{text}</span>}\n </td>\n </tr>\n </tbody>\n );\n}\n","import { CSSProperties, ReactNode } from 'react';\nimport { useSortable } from '@dnd-kit/sortable';\nimport { CSS } from '@dnd-kit/utilities';\nimport { Header } from '@tanstack/react-table';\n\nimport type { ExtendedEntry } from '../../../../common/utils/rundownMetadata';\n\nimport style from '../CuesheetTable.module.scss';\n\ninterface SortableCellProps {\n columnId: string;\n colSpan: number;\n injectedStyles: CSSProperties;\n children: ReactNode;\n draggable: ReactNode;\n}\n\nexport function SortableCell({ columnId, colSpan, injectedStyles, children, draggable }: SortableCellProps) {\n const { attributes, listeners, setNodeRef, transform, transition, isDragging } = useSortable({\n id: columnId,\n });\n\n // build drag styles\n const dragStyle = {\n ...injectedStyles,\n zIndex: isDragging ? 2 : 'inherit',\n transform: CSS.Translate.toString(transform),\n transition,\n };\n\n return (\n <th ref={setNodeRef} style={dragStyle} colSpan={colSpan} tabIndex={-1}>\n <div {...attributes} {...listeners}>\n {children}\n </div>\n {draggable}\n </th>\n );\n}\n\nexport function TableCell({ colSpan, injectedStyles, children, draggable }: SortableCellProps) {\n return (\n <th style={injectedStyles} colSpan={colSpan} tabIndex={-1}>\n <div>{children}</div>\n {draggable}\n </th>\n );\n}\n\ninterface DraggableProps {\n header: Header<ExtendedEntry, unknown>;\n}\n\nexport function Draggable({ header }: DraggableProps) {\n return (\n <div\n onDoubleClick={() => header.column.resetSize()}\n onMouseDown={header.getResizeHandler()}\n onTouchStart={header.getResizeHandler()}\n className={style.resizer}\n />\n );\n}\n","import { CSSProperties } from 'react';\nimport { horizontalListSortingStrategy, SortableContext } from '@dnd-kit/sortable';\nimport { flexRender, HeaderGroup } from '@tanstack/react-table';\n\nimport type { ExtendedEntry } from '../../../../common/utils/rundownMetadata';\nimport { getAccessibleColour } from '../../../../common/utils/styleUtils';\nimport { AppMode } from '../../../../ontimeConfig';\nimport { usePersistedCuesheetOptions } from '../../cuesheet.options';\n\nimport { Draggable, SortableCell, TableCell } from './SortableCell';\n\nimport style from '../CuesheetTable.module.scss';\n\ninterface CuesheetHeaderProps {\n headerGroup: HeaderGroup<ExtendedEntry>;\n cuesheetMode: AppMode;\n}\n\nexport function SortableCuesheetHeader({ headerGroup, cuesheetMode }: CuesheetHeaderProps) {\n const hideIndexColumn = usePersistedCuesheetOptions((state) => state.hideIndexColumn);\n\n return (\n <tr key={headerGroup.id}>\n {cuesheetMode === AppMode.Edit && <th className={style.actionColumn} tabIndex={-1} />}\n {!hideIndexColumn && (\n <th className={style.indexColumn} tabIndex={-1}>\n #\n </th>\n )}\n <SortableContext key={headerGroup.id} items={headerGroup.headers} strategy={horizontalListSortingStrategy}>\n {headerGroup.headers.map((header) => {\n const customBackground = header.column.columnDef.meta?.colour;\n const canWrite = header.column.columnDef.meta?.canWrite;\n\n const customStyles: CSSProperties = {\n opacity: canWrite ? 1 : 0.6,\n };\n if (customBackground) {\n const customColour = getAccessibleColour(customBackground);\n customStyles.backgroundColor = customColour.backgroundColor;\n customStyles.color = customColour.color;\n }\n\n return (\n <SortableCell\n key={header.column.columnDef.id}\n columnId={header.column.id}\n colSpan={header.colSpan}\n injectedStyles={{ width: `calc(var(--header-${header?.id}-size) * 1px)`, ...customStyles }}\n draggable={<Draggable header={header} />}\n >\n {header.isPlaceholder ? null : flexRender(header.column.columnDef.header, header.getContext())}\n </SortableCell>\n );\n })}\n </SortableContext>\n </tr>\n );\n}\n\nexport function CuesheetHeader({ headerGroup, cuesheetMode }: CuesheetHeaderProps) {\n const hideIndexColumn = usePersistedCuesheetOptions((state) => state.hideIndexColumn);\n\n return (\n <tr key={headerGroup.id}>\n {cuesheetMode === AppMode.Edit && <th className={style.actionColumn} tabIndex={-1} />}\n {!hideIndexColumn && (\n <th className={style.indexColumn} tabIndex={-1}>\n #\n </th>\n )}\n {headerGroup.headers.map((header) => {\n const customBackground = header.column.columnDef.meta?.colour;\n const canWrite = header.column.columnDef.meta?.canWrite;\n\n const customStyles: CSSProperties = {\n opacity: canWrite ? 1 : 0.6,\n };\n if (customBackground) {\n const customColour = getAccessibleColour(customBackground);\n customStyles.backgroundColor = customColour.backgroundColor;\n customStyles.color = customColour.color;\n }\n\n return (\n <TableCell\n key={header.column.columnDef.id}\n columnId={header.column.id}\n colSpan={header.colSpan}\n injectedStyles={{ width: `calc(var(--header-${header?.id}-size) * 1px)`, ...customStyles }}\n draggable={<Draggable header={header} />}\n >\n {header.isPlaceholder ? null : flexRender(header.column.columnDef.header, header.getContext())}\n </TableCell>\n );\n })}\n </tr>\n );\n}\n","import { CSSProperties, memo } from 'react';\n\nimport { millisToDelayString } from '../../../../common/utils/dateConfig';\nimport { usePersistedCuesheetOptions } from '../../cuesheet.options';\n\nimport style from './DelayRow.module.scss';\n\ninterface DelayRowProps {\n duration: number;\n injectedStyles?: CSSProperties;\n}\n\nfunction DelayRow({ duration, injectedStyles, ...virtuosoProps }: DelayRowProps) {\n const hideDelays = usePersistedCuesheetOptions((state) => state.hideDelays);\n\n if (hideDelays || duration === 0) {\n return null;\n }\n\n const delayTime = millisToDelayString(duration, 'expanded');\n\n return (\n <tr className={style.delayRow} data-testid='cuesheet-delay' style={injectedStyles} {...virtuosoProps}>\n <td tabIndex={0}>{delayTime}</td>\n </tr>\n );\n}\n\nexport default memo(DelayRow);\n","import { EntryId, SupportedEntry } from 'ontime-types';\nimport { create } from 'zustand';\n\ntype Anchor = { x: number; y: number };\n\ntype OpenMenu = {\n isOpen: true;\n entryId: EntryId;\n entryType: SupportedEntry;\n entryIndex: number;\n parentId: EntryId | null;\n flag: boolean | null;\n};\n\ntype ClosedMenu = {\n isOpen: false;\n entryId: null;\n entryType: null;\n entryIndex: null;\n parentId: null;\n flag: null;\n};\n\ntype CuesheetTableMenuStore = (OpenMenu | ClosedMenu) & {\n position: Anchor;\n openMenu: (\n position: Anchor,\n entryId: EntryId,\n entryType: SupportedEntry,\n entryIndex: number,\n parentId: EntryId | null,\n flag: boolean | null,\n ) => void;\n closeMenu: () => void;\n};\n\nexport const useCuesheetTableMenu = create<CuesheetTableMenuStore>((set) => ({\n isOpen: false,\n entryId: null,\n entryType: null,\n entryIndex: null,\n parentId: null,\n position: { x: 0, y: 0 },\n flag: null,\n openMenu: (\n position: Anchor,\n entryId: EntryId,\n entryType: SupportedEntry,\n entryIndex: number,\n parentId: EntryId | null,\n flag: null | boolean,\n ) => set({ isOpen: true, position, entryId, entryType, entryIndex, parentId, flag }),\n closeMenu: () => set({ isOpen: false }),\n}));\n","import { CSSProperties, useMemo } from 'react';\nimport { IoEllipsisHorizontal } from 'react-icons/io5';\nimport { flexRender, Table } from '@tanstack/react-table';\nimport { EntryId, OntimeEntry, RGBColour, SupportedEntry } from 'ontime-types';\nimport { colourToHex, cssOrHexToColour } from 'ontime-utils';\n\nimport IconButton from '../../../../common/components/buttons/IconButton';\nimport type { ExtendedEntry } from '../../../../common/utils/rundownMetadata';\nimport { cx, getAccessibleColour } from '../../../../common/utils/styleUtils';\nimport { AppMode } from '../../../../ontimeConfig';\nimport { useCuesheetTableMenu } from '../cuesheet-table-menu/useCuesheetTableMenu';\n\nimport style from './EventRow.module.scss';\n\ninterface EventRowProps {\n rowId: string;\n id: EntryId;\n eventIndex: number;\n colour: string;\n isFirstAfterGroup: boolean;\n isLoaded: boolean;\n isPast: boolean;\n groupColour: string | undefined;\n flag: boolean;\n skip: boolean;\n parent: EntryId | null;\n rowIndex: number;\n table: Table<ExtendedEntry<OntimeEntry>>;\n injectedStyles?: CSSProperties;\n}\n\nexport default function EventRow({\n rowId,\n id,\n eventIndex,\n colour,\n isFirstAfterGroup,\n isLoaded,\n isPast,\n groupColour,\n flag,\n skip,\n parent,\n rowIndex,\n table,\n injectedStyles,\n ...virtuosoProps\n}: EventRowProps) {\n const { cuesheetMode, hideIndexColumn } = table.options.meta?.options ?? {\n cuesheetMode: AppMode.Edit,\n hideIndexColumn: false,\n };\n\n const openMenu = useCuesheetTableMenu((store) => store.openMenu);\n\n const { color, backgroundColor } = getAccessibleColour(colour);\n const tmpColour = cssOrHexToColour(color) as RGBColour; // we know this to be a correct colour\n const mutedText = colourToHex({ ...tmpColour, alpha: tmpColour.alpha * 0.8 });\n\n const rowBgColour: string | undefined = useMemo(() => {\n if (isLoaded) {\n return '#087A27'; // $active-green\n } else if (colour) {\n // the colour is user defined and might be invalid\n const accessibleBackgroundColor = cssOrHexToColour(getAccessibleColour(colour).backgroundColor);\n if (accessibleBackgroundColor !== null) {\n return colourToHex({\n ...accessibleBackgroundColor,\n alpha: accessibleBackgroundColor.alpha * 0.25,\n });\n }\n }\n return;\n }, [colour, isLoaded]);\n\n return (\n <tr\n id={rowId}\n className={cx([\n style.eventRow,\n skip && style.skip,\n isFirstAfterGroup && style.firstAfterGroup,\n parent && style.hasParent,\n ])}\n style={{\n ...injectedStyles,\n opacity: `${isPast ? '0.2' : '1'}`,\n '--user-bg': groupColour ?? 'transparent',\n }}\n data-testid='cuesheet-event'\n {...virtuosoProps}\n >\n {cuesheetMode === AppMode.Edit && (\n <td className={style.actionColumn} tabIndex={-1} role='cell'>\n <IconButton\n aria-label='Options'\n variant='ghosted-white'\n size='small'\n onClick={(e) => {\n const rect = e.currentTarget.getBoundingClientRect();\n const yPos = 8 + rect.y + rect.height / 2;\n openMenu({ x: rect.x, y: yPos }, id, SupportedEntry.Event, rowIndex, parent, flag);\n }}\n >\n <IoEllipsisHorizontal />\n </IconButton>\n </td>\n )}\n {!hideIndexColumn && (\n <td className={style.indexColumn} style={{ backgroundColor, color: mutedText }} tabIndex={-1} role='cell'>\n {eventIndex}\n </td>\n )}\n {table\n .getRow(rowId)\n .getVisibleCells()\n .map((cell) => {\n return (\n <td\n key={cell.id}\n style={{\n width: `calc(var(--col-${cell.column.id}-size) * 1px)`,\n backgroundColor: rowBgColour,\n }}\n tabIndex={-1}\n role='cell'\n >\n {flexRender(cell.column.columnDef.cell, cell.getContext())}\n </td>\n );\n })}\n </tr>\n );\n}\n","import { CSSProperties } from 'react';\nimport { IoEllipsisHorizontal } from 'react-icons/io5';\nimport { flexRender, Table } from '@tanstack/react-table';\nimport { EntryId, SupportedEntry } from 'ontime-types';\n\nimport IconButton from '../../../../common/components/buttons/IconButton';\nimport type { ExtendedEntry } from '../../../../common/utils/rundownMetadata';\nimport { AppMode } from '../../../../ontimeConfig';\nimport { useCuesheetTableMenu } from '../cuesheet-table-menu/useCuesheetTableMenu';\n\nimport style from './GroupRow.module.scss';\n\ninterface GroupRowProps {\n groupId: EntryId;\n colour: string;\n rowId: string;\n rowIndex: number;\n table: Table<ExtendedEntry>;\n injectedStyles?: CSSProperties;\n}\n\nexport default function GroupRow({\n groupId,\n colour,\n rowId,\n rowIndex,\n table,\n injectedStyles,\n ...virtuosoProps\n}: GroupRowProps) {\n const { cuesheetMode, hideIndexColumn } = table.options.meta?.options ?? {\n cuesheetMode: AppMode.Edit,\n hideIndexColumn: false,\n };\n\n const openMenu = useCuesheetTableMenu((store) => store.openMenu);\n\n return (\n <tr\n className={style.groupRow}\n style={{ ...injectedStyles, '--user-bg': colour }}\n data-testid='cuesheet-group'\n {...virtuosoProps}\n >\n {cuesheetMode === AppMode.Edit && (\n <td className={style.actionColumn} tabIndex={-1} role='cell'>\n <IconButton\n aria-label='Options'\n variant='ghosted-white'\n size='small'\n onClick={(e) => {\n const rect = e.currentTarget.getBoundingClientRect();\n const yPos = 8 + rect.y + rect.height / 2;\n openMenu({ x: rect.x, y: yPos }, groupId, SupportedEntry.Group, rowIndex, null, null);\n }}\n >\n <IoEllipsisHorizontal />\n </IconButton>\n </td>\n )}\n {!hideIndexColumn && <td className={style.indexColumn} tabIndex={-1} role='cell' />}\n {table\n .getRow(rowId)\n .getVisibleCells()\n .map((cell) => {\n return (\n <td\n key={cell.id}\n tabIndex={-1}\n style={{\n width: `calc(var(--col-${cell.column.id}-size) * 1px)`,\n }}\n role='cell'\n >\n {flexRender(cell.column.columnDef.cell, cell.getContext())}\n </td>\n );\n })}\n </tr>\n );\n}\n","import { CSSProperties } from 'react';\nimport { IoEllipsisHorizontal } from 'react-icons/io5';\nimport { flexRender, Table } from '@tanstack/react-table';\nimport { EntryId, SupportedEntry } from 'ontime-types';\nimport { colourToHex, cssOrHexToColour } from 'ontime-utils';\n\nimport IconButton from '../../../../common/components/buttons/IconButton';\nimport type { ExtendedEntry } from '../../../../common/utils/rundownMetadata';\nimport { cx, enDash, getAccessibleColour } from '../../../../common/utils/styleUtils';\nimport { AppMode } from '../../../../ontimeConfig';\nimport { useCuesheetTableMenu } from '../cuesheet-table-menu/useCuesheetTableMenu';\n\nimport style from './MilestoneRow.module.scss';\n\ninterface MilestoneRowProps {\n entryId: EntryId;\n isPast: boolean;\n parentBgColour?: string;\n parentId: EntryId | null;\n colour: string;\n rowId: string;\n rowIndex: number;\n table: Table<ExtendedEntry>;\n injectedStyles?: CSSProperties;\n}\n\nexport default function MilestoneRow({\n entryId,\n isPast,\n parentBgColour,\n parentId,\n colour,\n rowId,\n rowIndex,\n table,\n injectedStyles,\n ...virtuosoProps\n}: MilestoneRowProps) {\n const { cuesheetMode, hideIndexColumn } = table.options.meta?.options ?? {\n cuesheetMode: AppMode.Edit,\n hideIndexColumn: false,\n };\n\n const openMenu = useCuesheetTableMenu((store) => store.openMenu);\n\n let rowBgColour: string | undefined;\n if (colour) {\n // the colour is user defined and might be invalid\n const accessibleBackgroundColor = cssOrHexToColour(getAccessibleColour(colour).backgroundColor);\n if (accessibleBackgroundColor !== null) {\n rowBgColour = colourToHex({\n ...accessibleBackgroundColor,\n alpha: accessibleBackgroundColor.alpha * 0.25,\n });\n }\n }\n\n return (\n <tr\n className={cx([style.milestoneRow, Boolean(parentBgColour) && style.hasParent])}\n style={{\n ...injectedStyles,\n opacity: `${isPast ? '0.2' : '1'}`,\n '--user-bg': parentBgColour ?? 'transparent',\n }}\n data-testid='cuesheet-milestone'\n {...virtuosoProps}\n >\n {cuesheetMode === AppMode.Edit && (\n <td className={style.actionColumn} tabIndex={-1} role='cell'>\n <IconButton\n aria-label='Options'\n variant='ghosted-white'\n size='small'\n onClick={(e) => {\n const rect = e.currentTarget.getBoundingClientRect();\n const yPos = 8 + rect.y + rect.height / 2;\n openMenu({ x: rect.x, y: yPos }, entryId, SupportedEntry.Milestone, rowIndex, parentId, null);\n }}\n >\n <IoEllipsisHorizontal />\n </IconButton>\n </td>\n )}\n {!hideIndexColumn && (\n <td className={style.indexColumn} tabIndex={-1} role='cell'>\n {enDash}\n </td>\n )}\n {table\n .getRow(rowId)\n .getVisibleCells()\n .map((cell) => {\n const canRender =\n cell.column.id !== 'duration' && cell.column.id !== 'timeStart' && cell.column.id !== 'timeEnd';\n return (\n <td\n key={cell.id}\n style={{\n width: `calc(var(--col-${cell.column.id}-size) * 1px)`,\n backgroundColor: rowBgColour,\n opacity: canRender ? 1 : 0.4,\n }}\n tabIndex={-1}\n >\n {canRender && flexRender(cell.column.columnDef.cell, cell.getContext())}\n </td>\n );\n })}\n </tr>\n );\n}\n","import { create } from 'zustand';\n\ninterface CuesheetPermissionsStore {\n canChangeMode: boolean;\n canCreateEntries: boolean;\n canEditEntries: boolean;\n canFlag: boolean;\n canShare: boolean;\n setPermissions: (permissions: Omit<CuesheetPermissionsStore, 'setPermissions'>) => void;\n}\n\nexport const useCuesheetPermissions = create<CuesheetPermissionsStore>((set) => ({\n canChangeMode: false,\n canCreateEntries: false,\n canEditEntries: false,\n canFlag: false,\n canShare: false,\n setPermissions(permissions) {\n set({\n canChangeMode: permissions.canChangeMode,\n canFlag: permissions.canFlag,\n canCreateEntries: permissions.canCreateEntries,\n canEditEntries: permissions.canEditEntries,\n canShare: permissions.canShare,\n });\n },\n}));\n","import { memo } from 'react';\nimport { IoAdd, IoArrowDown, IoArrowUp, IoDuplicateOutline, IoOptions, IoTrash } from 'react-icons/io5';\nimport { SupportedEntry } from 'ontime-types';\n\nimport { PositionedDropdownMenu } from '../../../../common/components/dropdown-menu/DropdownMenu';\nimport { useEntryActions } from '../../../../common/hooks/useEntryAction';\nimport { useCuesheetEditModal } from '../../cuesheet-edit-modal/useCuesheetEditModal';\nimport { useCuesheetPermissions } from '../../useTablePermissions';\n\nimport { useCuesheetTableMenu } from './useCuesheetTableMenu';\n\nexport default memo(CuesheetTableMenu);\n\nfunction CuesheetTableMenu() {\n const { isOpen, entryId, entryIndex, parentId, flag, position, closeMenu } = useCuesheetTableMenu();\n const { addEntry, clone, deleteEntry, move, updateEntry } = useEntryActions();\n const showModal = useCuesheetEditModal((state) => state.setEditableEntry);\n const permissions = useCuesheetPermissions();\n\n if (!isOpen) {\n return null;\n }\n\n return (\n <PositionedDropdownMenu\n isOpen\n onClose={closeMenu}\n items={[\n {\n type: 'item',\n label: 'Edit...',\n onClick: () => showModal(entryId),\n icon: IoOptions,\n disabled: !permissions.canEditEntries,\n },\n { type: 'divider' },\n {\n type: 'item',\n label: flag ? 'Remove flag' : 'Add flag',\n onClick: () => updateEntry({ id: entryId, flag: !flag }),\n icon: IoDuplicateOutline,\n disabled: flag === null || !permissions.canFlag,\n },\n { type: 'divider' },\n {\n type: 'item',\n label: 'Add event above',\n onClick: () => addEntry({ type: SupportedEntry.Event, parent: parentId }, { before: entryId }),\n icon: IoAdd,\n disabled: !permissions.canCreateEntries,\n },\n {\n type: 'item',\n label: 'Add event below',\n onClick: () => addEntry({ type: SupportedEntry.Event, parent: parentId }, { after: entryId }),\n icon: IoAdd,\n disabled: !permissions.canCreateEntries,\n },\n {\n type: 'item',\n label: 'Clone event',\n onClick: () => clone(entryId),\n icon: IoDuplicateOutline,\n disabled: !permissions.canCreateEntries,\n },\n { type: 'divider' },\n {\n type: 'item',\n label: 'Move up',\n onClick: () => move(entryId, 'up'),\n icon: IoArrowUp,\n disabled: entryIndex < 1 || !permissions.canEditEntries,\n },\n {\n type: 'item',\n label: 'Move down',\n onClick: () => move(entryId, 'down'),\n icon: IoArrowDown,\n disabled: !permissions.canEditEntries,\n },\n { type: 'divider' },\n {\n type: 'item',\n label: 'Delete',\n onClick: () => deleteEntry([entryId]),\n icon: IoTrash,\n disabled: !permissions.canEditEntries,\n },\n ]}\n position={position}\n />\n );\n}\n","import { IconBaseProps } from 'react-icons';\nimport { IoLink } from 'react-icons/io5';\n\nexport default function RotatedLink(linkProps: IconBaseProps) {\n return <IoLink style={{ transform: 'rotate(-45deg)' }} {...linkProps} />;\n}\n","import { Toolbar } from '@base-ui-components/react/toolbar';\nimport { useDisclosure } from '@mantine/hooks';\nimport { OntimeView } from 'ontime-types';\n\nimport Button from '../../../../common/components/buttons/Button';\nimport RotatedLink from '../../../../common/components/icons/RotatedLink';\nimport Modal from '../../../../common/components/modal/Modal';\nimport useInfo from '../../../../common/hooks-query/useInfo';\nimport useUrlPresets from '../../../../common/hooks-query/useUrlPresets';\nimport GenerateLinkFormExport from '../../../../features/sharing/GenerateLinkFormExport';\n\nfunction CuesheetShareModal() {\n const { data: infoData } = useInfo();\n const { data: urlPresetData } = useUrlPresets();\n const [isOpen, handler] = useDisclosure();\n\n // Don't render the modal content until it's open and data is loaded\n const showModalContent = isOpen && infoData && urlPresetData;\n\n return (\n <>\n <Toolbar.Button onClick={handler.open} render={<Button />}>\n <RotatedLink />\n Share...\n </Toolbar.Button>\n <Modal\n isOpen={isOpen}\n onClose={handler.close}\n title='Share cuesheet view'\n showBackdrop\n showCloseButton\n bodyElements={\n showModalContent ? (\n <GenerateLinkFormExport lockedPath={{ value: OntimeView.Cuesheet, label: 'Cuesheet' }} />\n ) : null\n }\n />\n </>\n );\n}\n\nexport default CuesheetShareModal;\n","import { ReactNode, use } from 'react';\nimport { IoChevronDown, IoOptions, IoSettingsOutline } from 'react-icons/io5';\nimport { Popover } from '@base-ui-components/react/popover';\nimport { Toggle } from '@base-ui-components/react/toggle';\nimport { ToggleGroup } from '@base-ui-components/react/toggle-group';\nimport { Toolbar } from '@base-ui-components/react/toolbar';\nimport { useSessionStorage } from '@mantine/hooks';\nimport type { Column } from '@tanstack/react-table';\n\nimport Button from '../../../../common/components/buttons/Button';\nimport Checkbox from '../../../../common/components/checkbox/Checkbox';\nimport * as Editor from '../../../../common/components/editor-utils/EditorUtils';\nimport PopoverContents from '../../../../common/components/popover/Popover';\nimport { PresetContext } from '../../../../common/context/PresetContext';\nimport type { ExtendedEntry } from '../../../../common/utils/rundownMetadata';\nimport { cx } from '../../../../common/utils/styleUtils';\nimport { AppMode, sessionKeys } from '../../../../ontimeConfig';\nimport { usePersistedCuesheetOptions } from '../../cuesheet.options';\nimport { useCuesheetPermissions } from '../../useTablePermissions';\n\nimport CuesheetShareModal from './CuesheetShareModal';\n\nimport style from './CuesheetTableSettings.module.scss';\n\ninterface CuesheetTableSettingsProps {\n columns: Column<ExtendedEntry, unknown>[];\n handleResetResizing: () => void;\n handleResetReordering: () => void;\n handleClearToggles: () => void;\n}\n\nexport default function CuesheetTableSettings({\n columns,\n handleResetResizing,\n handleResetReordering,\n handleClearToggles,\n}: CuesheetTableSettingsProps) {\n const canShare = useCuesheetPermissions((state) => state.canShare);\n const preset = use(PresetContext);\n\n const [cuesheetMode, setCuesheetMode] = useSessionStorage({\n key: preset ? `${preset.alias}${sessionKeys.cuesheetMode}` : sessionKeys.cuesheetMode,\n defaultValue: preset ? AppMode.Run : AppMode.Edit,\n });\n\n const toggleCuesheetMode = (mode: AppMode[]) => {\n // we need to stop user from deselecting a mode\n const newValue = mode.at(0);\n if (!newValue) return;\n setCuesheetMode(newValue);\n };\n\n return (\n <Toolbar.Root className={style.tableSettings}>\n <ViewSettings />\n <ColumnSettings\n columns={columns}\n handleResetResizing={handleResetResizing}\n handleResetReordering={handleResetReordering}\n handleClearToggles={handleClearToggles}\n />\n <ToggleGroup value={[cuesheetMode]} onValueChange={toggleCuesheetMode} className={cx([style.group, style.apart])}>\n <Toolbar.Button render={<Toggle />} value={AppMode.Run} className={style.radioButton}>\n Run\n </Toolbar.Button>\n <Toolbar.Button render={<Toggle />} value={AppMode.Edit} className={style.radioButton}>\n Edit\n </Toolbar.Button>\n </ToggleGroup>\n\n {canShare && (\n <>\n <Editor.Separator orientation='vertical' />\n <CuesheetShareModal />\n </>\n )}\n </Toolbar.Root>\n );\n}\n\nfunction ViewSettings() {\n const options = usePersistedCuesheetOptions();\n\n return (\n <Popover.Root>\n <Popover.Trigger\n render={\n <Toolbar.Button\n render={\n <Button variant='ghosted-white'>\n <IoSettingsOutline /> Settings\n <IoChevronDown />\n </Button>\n }\n />\n }\n />\n\n <PopoverContents align='start' className={style.inline}>\n <div className={style.column}>\n <Editor.Label className={style.sectionTitle}>Element visibility</Editor.Label>\n <Editor.Label className={style.option}>\n <Checkbox\n defaultChecked={options.hideTableSeconds}\n onCheckedChange={(checked) => options.setOption('hideTableSeconds', checked)}\n />\n Hide seconds in table\n </Editor.Label>\n <Editor.Label className={style.option}>\n <Checkbox\n defaultChecked={options.hideIndexColumn}\n onCheckedChange={(checked) => options.setOption('hideIndexColumn', checked)}\n />\n Hide index column\n </Editor.Label>\n </div>\n\n <div className={style.column}>\n <Editor.Label className={style.sectionTitle}>Table Behaviour</Editor.Label>\n <Editor.Label className={style.option}>\n <Checkbox\n defaultChecked={options.showDelayedTimes}\n onCheckedChange={(checked) => options.setOption('showDelayedTimes', checked)}\n />\n Show delayed times\n </Editor.Label>\n <Editor.Label className={style.option}>\n <Checkbox\n defaultChecked={options.hideDelays}\n onCheckedChange={(checked) => options.setOption('hideDelays', checked)}\n />\n Hide delay entries\n </Editor.Label>\n </div>\n </PopoverContents>\n </Popover.Root>\n );\n}\n\nfunction ColumnSettings({\n columns,\n handleResetResizing,\n handleResetReordering,\n handleClearToggles,\n}: CuesheetTableSettingsProps) {\n return (\n <Popover.Root>\n <Popover.Trigger\n render={\n <Toolbar.Button\n render={\n <Button variant='ghosted-white'>\n <IoOptions /> View\n <IoChevronDown />\n </Button>\n }\n />\n }\n />\n <PopoverContents align='start' className={style.inline}>\n <div className={style.column}>\n <Editor.Label className={style.sectionTitle}>Column visibility</Editor.Label>\n {columns.map((column) => {\n const columnHeader = column.columnDef.header;\n const visible = column.getIsVisible();\n return (\n <Editor.Label key={`${column.id}-${visible}`} className={style.option}>\n <Checkbox defaultChecked={visible} onCheckedChange={column.toggleVisibility} />\n {columnHeader as ReactNode}\n </Editor.Label>\n );\n })}\n </div>\n <Editor.Separator orientation='vertical' />\n <div className={style.column}>\n <Editor.Label className={style.sectionTitle}>Reset Options</Editor.Label>\n <Button size='small' fluid onClick={handleClearToggles}>\n Show All\n </Button>\n <Button size='small' fluid onClick={handleResetResizing}>\n Reset Resizing\n </Button>\n <Button size='small' fluid onClick={handleResetReordering}>\n Reset Reordering\n </Button>\n </div>\n </PopoverContents>\n </Popover.Root>\n );\n}\n","import { useCallback, useEffect, useMemo, useRef } from 'react';\nimport { TableVirtuoso, TableVirtuosoHandle } from 'react-virtuoso';\nimport { useTableNav } from '@table-nav/react';\nimport { ColumnDef, getCoreRowModel, useReactTable } from '@tanstack/react-table';\nimport { isOntimeDelay, isOntimeGroup, isOntimeMilestone, OntimeEntry, TimeField } from 'ontime-types';\n\nimport EmptyPage from '../../../common/components/state/EmptyPage';\nimport EmptyTableBody from '../../../common/components/state/EmptyTableBody';\nimport { useEntryActions } from '../../../common/hooks/useEntryAction';\nimport { useSelectedEventId } from '../../../common/hooks/useSocket';\nimport { useFlatRundownWithMetadata } from '../../../common/hooks-query/useRundown';\nimport type { ExtendedEntry } from '../../../common/utils/rundownMetadata';\nimport { AppMode } from '../../../ontimeConfig';\nimport { usePersistedCuesheetOptions } from '../cuesheet.options';\n\nimport { CuesheetHeader, SortableCuesheetHeader } from './cuesheet-table-elements/CuesheetHeader';\nimport DelayRow from './cuesheet-table-elements/DelayRow';\nimport EventRow from './cuesheet-table-elements/EventRow';\nimport GroupRow from './cuesheet-table-elements/GroupRow';\nimport MilestoneRow from './cuesheet-table-elements/MilestoneRow';\nimport CuesheetTableMenu from './cuesheet-table-menu/CuesheetTableMenu';\nimport CuesheetTableSettings from './cuesheet-table-settings/CuesheetTableSettings';\nimport { useColumnOrder, useColumnSizes, useColumnVisibility } from './useColumnManager';\n\nimport style from './CuesheetTable.module.scss';\n\ninterface CuesheetTableProps {\n columns: ColumnDef<ExtendedEntry>[];\n cuesheetMode: AppMode;\n}\n\nexport default function CuesheetTable({ columns, cuesheetMode }: CuesheetTableProps) {\n const { data, status } = useFlatRundownWithMetadata();\n const { updateEntry, updateTimer } = useEntryActions();\n const showDelayedTimes = usePersistedCuesheetOptions((state) => state.showDelayedTimes);\n const hideTableSeconds = usePersistedCuesheetOptions((state) => state.hideTableSeconds);\n const hideIndexColumn = usePersistedCuesheetOptions((state) => state.hideIndexColumn);\n\n const { selectedEventId } = useSelectedEventId();\n\n const virtuosoRef = useRef<TableVirtuosoHandle | null>(null);\n const { listeners } = useTableNav();\n\n const meta = useMemo(\n () => ({\n handleUpdate: (rowIndex: number, accessor: string, payload: string, isCustom = false) => {\n // check if value is the same\n const event = data[rowIndex];\n\n if (!event) {\n return;\n }\n\n // skip if there is no value change\n const key = accessor as keyof OntimeEntry;\n const previousValue = event[key];\n if (previousValue === payload) {\n return;\n }\n\n if (isCustom) {\n updateEntry({ id: event.id, custom: { [accessor]: payload } });\n return;\n }\n\n updateEntry({ id: event.id, [accessor]: payload });\n },\n handleUpdateTimer: (eventId: string, field: TimeField, payload: string) => {\n // the timer element already contains logic to avoid submitting a unchanged value\n updateTimer(eventId, field, payload, true);\n },\n options: {\n showDelayedTimes,\n hideTableSeconds,\n cuesheetMode,\n hideIndexColumn,\n },\n }),\n [cuesheetMode, data, hideIndexColumn, hideTableSeconds, showDelayedTimes, updateEntry, updateTimer],\n );\n\n const { columnOrder, resetColumnOrder } = useColumnOrder(columns);\n const { columnSizing, setColumnSizing } = useColumnSizes();\n const { columnVisibility, setColumnVisibility } = useColumnVisibility();\n\n const table = useReactTable({\n data,\n columns,\n columnResizeMode: 'onChange',\n state: {\n columnOrder,\n columnVisibility,\n columnSizing,\n },\n onColumnVisibilityChange: setColumnVisibility,\n onColumnSizingChange: setColumnSizing,\n getCoreRowModel: getCoreRowModel(),\n meta,\n });\n\n const setAllVisible = useCallback(() => {\n table.toggleAllColumnsVisible(true);\n }, [table]);\n\n const resetColumnResizing = useCallback(() => {\n setColumnSizing({});\n }, [setColumnSizing]);\n\n // in run mode, we follow the selected row\n useEffect(() => {\n if (cuesheetMode === AppMode.Edit || virtuosoRef.current === null || !selectedEventId) {\n return;\n }\n\n const eventIndex = data.findIndex((event) => event.id === selectedEventId);\n virtuosoRef.current.scrollToIndex({ index: eventIndex, behavior: 'smooth' });\n }, [cuesheetMode, data, selectedEventId]);\n\n /**\n * To improve performance on resizing, we memoise the column sizes\n * and pass them as CSS variables to the table container.\n */\n const columnSizeVars = useMemo(() => {\n const headers = table.getFlatHeaders();\n const colSizes: { [key: string]: number } = {};\n for (let i = 0; i < headers.length; i++) {\n const header = headers[i];\n if (!header) continue;\n colSizes[`--header-${header.id}-size`] = header.getSize();\n colSizes[`--col-${header.column.id}-size`] = header.column.getSize();\n }\n return colSizes;\n // eslint-disable-next-line react-compiler/react-compiler -- unfortunately this is what we need\n // eslint-disable-next-line react-hooks/exhaustive-deps -- this works well and follows documentation\n }, [table.getState().columnSizingInfo, table.getState().columnSizing]);\n\n const allLeafColumns = table.getAllLeafColumns();\n const { rows } = table.getRowModel();\n\n const isLoading = !data || status === 'pending';\n\n if (isLoading) {\n return <EmptyPage text='Loading...' />;\n }\n\n return (\n <>\n <CuesheetTableSettings\n columns={allLeafColumns}\n handleResetResizing={resetColumnResizing}\n handleResetReordering={resetColumnOrder}\n handleClearToggles={setAllVisible}\n />\n <TableVirtuoso\n ref={virtuosoRef}\n data={data}\n increaseViewportBy={{ top: 100, bottom: 200 }}\n components={{\n EmptyPlaceholder: () => <EmptyTableBody text='No data in rundown' />,\n Table: ({ style: injectedStyles, ...virtuosoProps }) => {\n return (\n <table\n className={style.cuesheet}\n id='cuesheet'\n style={{ ...injectedStyles, ...columnSizeVars }}\n {...listeners}\n {...virtuosoProps}\n />\n );\n },\n TableRow: ({ item: _item, style: injectedStyles, ...virtuosoProps }) => {\n // eslint-disable-next-line react/destructuring-assignment\n const rowIndex = virtuosoProps['data-index'];\n const row = rows[rowIndex];\n const key = row.original.id;\n const entry = row.original;\n\n if (isOntimeGroup(entry)) {\n return (\n <GroupRow\n key={key}\n groupId={entry.id}\n colour={entry.colour}\n rowId={row.id}\n rowIndex={row.index}\n table={table}\n injectedStyles={injectedStyles}\n {...virtuosoProps}\n />\n );\n }\n\n if (isOntimeDelay(entry)) {\n return (\n <DelayRow key={key} duration={entry.duration} injectedStyles={injectedStyles} {...virtuosoProps} />\n );\n }\n\n if (isOntimeMilestone(entry)) {\n return (\n <MilestoneRow\n key={key}\n entryId={entry.id}\n isPast={entry.isPast}\n parentBgColour={entry.groupColour}\n parentId={entry.parent}\n colour={entry.colour}\n rowId={row.id}\n rowIndex={rowIndex}\n table={table}\n injectedStyles={injectedStyles}\n {...virtuosoProps}\n />\n );\n }\n\n return (\n <EventRow\n key={row.id}\n id={entry.id}\n eventIndex={entry.eventIndex}\n colour={entry.colour}\n isFirstAfterGroup={entry.isFirstAfterGroup}\n isLoaded={entry.isLoaded}\n isPast={entry.isPast}\n groupColour={entry.groupColour}\n flag={entry.flag}\n skip={entry.skip}\n parent={entry.parent}\n rowId={row.id}\n rowIndex={rowIndex}\n table={table}\n injectedStyles={injectedStyles}\n {...virtuosoProps}\n />\n );\n },\n TableHead: (virtuosoProps) => <thead className={style.tableHeader} {...virtuosoProps} />,\n }}\n fixedHeaderContent={() => {\n return table.getHeaderGroups().map((headerGroup) => {\n const HeaderComponent = table.getState().columnSizingInfo.isResizingColumn\n ? CuesheetHeader\n : SortableCuesheetHeader;\n\n // if the table is being resized, we render non-sortable headers to avoid performance issues\n return <HeaderComponent key={headerGroup.id} cuesheetMode={cuesheetMode} headerGroup={headerGroup} />;\n });\n }}\n />\n\n <CuesheetTableMenu />\n </>\n );\n}\n","import { memo, use, useEffect, useMemo } from 'react';\nimport { useSessionStorage } from '@mantine/hooks';\n\nimport EmptyPage from '../../common/components/state/EmptyPage';\nimport { PresetContext } from '../../common/context/PresetContext';\nimport useCustomFields from '../../common/hooks-query/useCustomFields';\nimport { sessionScope } from '../../externals';\nimport { AppMode, sessionKeys } from '../../ontimeConfig';\n\nimport CuesheetDnd from './cuesheet-dnd/CuesheetDnd';\nimport { makeCuesheetColumns } from './cuesheet-table/cuesheet-table-elements/cuesheetColsFactory';\nimport CuesheetTable from './cuesheet-table/CuesheetTable';\nimport { useCuesheetPermissions } from './useTablePermissions';\n\nexport default memo(CuesheetTableWrapper);\nfunction CuesheetTableWrapper() {\n const { data: customFields, status: customFieldStatus } = useCustomFields();\n const setPermissions = useCuesheetPermissions((state) => state.setPermissions);\n const preset = use(PresetContext);\n\n // set permissions based on preset\n useEffect(() => {\n if (preset) {\n const fullWrite = preset.options?.write === 'full';\n setPermissions({\n canChangeMode: preset.options?.write !== '-',\n canCreateEntries: fullWrite,\n canEditEntries: fullWrite,\n canFlag: fullWrite || Boolean(preset.options?.write.includes('flag')),\n canShare: false, // TODO: should be sessionScope === 'rw' when we have granular scopes\n });\n } else {\n setPermissions({\n canChangeMode: true,\n canCreateEntries: true,\n canEditEntries: true,\n canFlag: true,\n canShare: sessionScope === 'rw',\n });\n }\n }, [preset, setPermissions]);\n\n const [cuesheetMode] = useSessionStorage({\n key: preset ? `${preset.alias}${sessionKeys.cuesheetMode}` : sessionKeys.cuesheetMode,\n defaultValue: preset ? AppMode.Run : AppMode.Edit,\n });\n\n const columns = useMemo(\n () => makeCuesheetColumns(customFields, cuesheetMode, preset),\n [customFields, cuesheetMode, preset],\n );\n\n const isLoading = !customFields || customFieldStatus === 'pending';\n\n return (\n <CuesheetDnd columns={columns}>\n {isLoading ? <EmptyPage text='Loading...' /> : <CuesheetTable columns={columns} cuesheetMode={cuesheetMode} />}\n </CuesheetDnd>\n );\n}\n","import { IoApps } from 'react-icons/io5';\nimport { useDisclosure } from '@mantine/hooks';\n\nimport IconButton from '../../common/components/buttons/IconButton';\nimport NavigationMenu from '../../common/components/navigation-menu/NavigationMenu';\nimport { useWindowTitle } from '../../common/hooks/useWindowTitle';\nimport { getIsNavigationLocked } from '../../externals';\nimport CuesheetOverview from '../../features/overview/CuesheetOverview';\n\nimport CuesheetEditModal from './cuesheet-edit-modal/CuesheetEditModal';\nimport CuesheetProgress from './cuesheet-progress/CuesheetProgress';\nimport CuesheetTableWrapper from './CuesheetTableWrapper';\n\nimport styles from './CuesheetPage.module.scss';\n\nexport default function CuesheetPage() {\n const [isMenuOpen, menuHandler] = useDisclosure();\n\n useWindowTitle('Cuesheet');\n\n const isLocked = getIsNavigationLocked();\n\n return (\n <>\n <NavigationMenu isOpen={isMenuOpen} onClose={menuHandler.close} />\n <CuesheetEditModal />\n <div className={styles.tableWrapper} data-testid='cuesheet'>\n <CuesheetOverview>\n {!isLocked && (\n <IconButton aria-label='Toggle navigation' variant='subtle-white' size='xlarge' onClick={menuHandler.open}>\n <IoApps />\n </IconButton>\n )}\n </CuesheetOverview>\n <CuesheetProgress />\n <CuesheetTableWrapper />\n </div>\n </>\n );\n}\n","import ProtectRoute from '../../common/components/protect-route/ProtectRoute';\n\nimport CuesheetPage from './CuesheetPage';\n\nexport default function ProtectedCuesheet() {\n return (\n <ProtectRoute permission='operator'>\n <CuesheetPage />\n </ProtectRoute>\n );\n}\n"],"names":["useIsMobileScreen","width","useViewportSize","useMemo","memo","CuesheetOverview","children","jsx","CuesheetMobile","CuesheetDesktop","jsxs","OverviewWrapper","TimerOverview","OffsetOverview","TitleOverview","StartTimes","MetadataTimes","ClockOverview","CuesheetEntryEditor","entryId","data","useRundown","entry","setEntry","useState","isOntimeEvent","useEffect","order","length","event","entries","style","entryEditor","EventEditor","isOntimeMilestone","inModal","MilestoneEditor","isOntimeGroup","GroupEditor","useCuesheetEditModal","create","set","selectedEntryId","setEditableEntry","clearSelection","CuesheetEditModal","state","closeModal","Modal","CuesheetProgress","useViewSettings","current","duration","timeWarning","timeDanger","useProgressData","MultiPartProgressBar","normalColor","warningColor","dangerColor","styles","progressOverride","debounce","callback","wait","timeout","args","clearTimeout","setTimeout","tableSizesKey","makeStageKey","tableHiddenKey","tableOrderKey","saveSizesToStorage","sizes","localStorage","setItem","JSON","stringify","useColumnSizes","columnSizing","setColumnSizingState","stored","getItem","parse","setColumnSizing","useCallback","sizesOrUpdater","useColumnOrder","columns","columnOrder","saveColumnOrder","useLocalStorage","key","defaultValue","map","col","id","newColumns","some","includes","resetColumnOrder","useColumnVisibility","columnVisibility","setColumnVisibility","CuesheetDnd","sensors","useSensors","useSensor","PointerSensor","activationConstraint","delay","tolerance","TouchSensor","handleOnDragEnd","delta","active","over","y","fromIndex","indexOf","toIndex","reorderedCols","reorderedItem","splice","DndContext","closestCorners","SingleLineCell","forwardRef","initialValue","allowSubmitSameValue","handleUpdate","handleCancelUpdate","inputRef","ref","useRef","submitCallback","newValue","value","onChange","onBlur","onKeyDown","useReactiveTextInput","allowKeyboardNavigation","submitOnEnter","submitOnCtrlEnter","onCancelUpdate","useImperativeHandle","focus","select","focusParentElement","parentElement","Input","displayName","DurationInput","lockedValue","delayed","onSubmit","isEditing","setIsEditing","setValue","textRef","handleFakeFocus","handleFakeBlur","startsWith","valueInMillis","parseUserTime","isNaN","Number","timeString","millisToString","TextLikeInput","undefined","EditableImage","readOnly","updateValue","openInNewTab","open","imageCell","overlay","Button","Boolean","image","imageInput","currentTarget","FlagCell","flag","TbFlagFilled","GhostedText","multiline","ghostedText","MultiLineCell","AutoTextarea","MutedText","numeric","cx","muted","TimeInputDuration","formatTime","MakeStart","getValue","row","table","column","options","meta","showDelayedTimes","hideTableSeconds","formatOpts","format12","format24","original","handleUpdateTimer","update","startTime","isStartLocked","linkStart","displayTime","formattedTime","columnDef","canWrite","TimeInput","DelayIndicator","MakeEnd","endTime","isEndLocked","timeStrategy","TimeStrategy","LockEnd","MakeDuration","formatDuration","isDurationLocked","LockDuration","formattedDuration","MakeMultiLineField","index","LazyImage","isOntimeDelay","custom","MakeSingleLineField","MakeFlagField","MakeCustomField","makeCuesheetColumns","customFields","cuesheetMode","preset","columnsDef","modeAllowsWrite","AppMode","Edit","fullRead","read","fullWrite","write","canWriteKeys","Set","split","canReadKeys","canRead","has","push","accessorKey","header","cell","size","minSize","customFieldKeys","Object","keys","i","permissionKey","label","type","colour","EmptyTableBody","text","emptyContainer","emptyCell","EmptyImage","empty","SortableCell","columnId","colSpan","injectedStyles","draggable","attributes","listeners","setNodeRef","transform","transition","isDragging","useSortable","dragStyle","zIndex","CSS","Translate","toString","TableCell","Draggable","resetSize","getResizeHandler","resizer","SortableCuesheetHeader","headerGroup","hideIndexColumn","usePersistedCuesheetOptions","actionColumn","indexColumn","SortableContext","headers","horizontalListSortingStrategy","customBackground","customStyles","opacity","customColour","getAccessibleColour","backgroundColor","color","isPlaceholder","flexRender","getContext","CuesheetHeader","DelayRow","virtuosoProps","hideDelays","delayTime","millisToDelayString","delayRow","useCuesheetTableMenu","isOpen","entryType","entryIndex","parentId","position","x","openMenu","closeMenu","EventRow","rowId","eventIndex","isFirstAfterGroup","isLoaded","isPast","groupColour","skip","parent","rowIndex","store","tmpColour","cssOrHexToColour","mutedText","colourToHex","alpha","rowBgColour","accessibleBackgroundColor","eventRow","firstAfterGroup","hasParent","IconButton","e","rect","getBoundingClientRect","yPos","height","SupportedEntry","Event","IoEllipsisHorizontal","getRow","getVisibleCells","GroupRow","groupId","groupRow","Group","MilestoneRow","parentBgColour","milestoneRow","Milestone","enDash","canRender","useCuesheetPermissions","canChangeMode","canCreateEntries","canEditEntries","canFlag","canShare","setPermissions","permissions","CuesheetTableMenu","addEntry","clone","deleteEntry","move","updateEntry","useEntryActions","showModal","PositionedDropdownMenu","onClick","icon","IoOptions","disabled","IoDuplicateOutline","before","IoAdd","after","IoArrowUp","IoArrowDown","IoTrash","RotatedLink","linkProps","IoLink","CuesheetShareModal","infoData","useInfo","urlPresetData","useUrlPresets","handler","useDisclosure","showModalContent","Fragment","Toolbar.Button","close","GenerateLinkFormExport","OntimeView","Cuesheet","CuesheetTableSettings","handleResetResizing","handleResetReordering","handleClearToggles","use","PresetContext","setCuesheetMode","useSessionStorage","alias","sessionKeys","Run","toggleCuesheetMode","mode","at","Toolbar.Root","tableSettings","ViewSettings","ColumnSettings","ToggleGroup","group","apart","Toggle","radioButton","Editor.Separator","Popover.Root","Popover.Trigger","IoSettingsOutline","IoChevronDown","PopoverContents","inline","Editor.Label","sectionTitle","option","Checkbox","setOption","checked","columnHeader","visible","getIsVisible","toggleVisibility","CuesheetTable","status","useFlatRundownWithMetadata","updateTimer","selectedEventId","useSelectedEventId","virtuosoRef","useTableNav","accessor","payload","isCustom","eventId","field","useReactTable","columnResizeMode","onColumnVisibilityChange","onColumnSizingChange","getCoreRowModel","setAllVisible","toggleAllColumnsVisible","resetColumnResizing","findIndex","scrollToIndex","behavior","columnSizeVars","getFlatHeaders","colSizes","getSize","getState","columnSizingInfo","allLeafColumns","getAllLeafColumns","rows","getRowModel","EmptyPage","TableVirtuoso","top","bottom","EmptyPlaceholder","Table","cuesheet","TableRow","item","_item","TableHead","tableHeader","getHeaderGroups","HeaderComponent","isResizingColumn","CuesheetTableWrapper","customFieldStatus","useCustomFields","sessionScope","isLoading","CuesheetPage","isMenuOpen","menuHandler","useWindowTitle","isLocked","getIsNavigationLocked","NavigationMenu","tableWrapper","IoApps","ProtectedCuesheet","ProtectRoute"],"mappings":"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"}