event-prepare.wxml 7.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140
  1. <scroll-view class="page" scroll-y>
  2. <view class="shell">
  3. <view class="hero">
  4. <view class="hero__eyebrow">Prepare</view>
  5. <view class="hero__title">{{titleText}}</view>
  6. <view class="hero__desc">{{summaryText}}</view>
  7. </view>
  8. <view class="panel">
  9. <view class="panel__title">活动与发布</view>
  10. <view class="summary">Release:{{releaseText}}</view>
  11. <view class="summary">主动作:{{actionText}}</view>
  12. <view class="summary">状态:{{statusText}}</view>
  13. <view class="summary">赛道模式:{{variantModeText}}</view>
  14. <view class="summary">赛道摘要:{{variantSummaryText}}</view>
  15. <view class="summary">当前选择:{{selectedVariantText}}</view>
  16. </view>
  17. <view class="panel">
  18. <view class="panel__title">活动运营摘要</view>
  19. <view class="summary">当前阶段先展示当前发布 release 绑定的活动运营对象摘要,不展开复杂 schema。</view>
  20. <view class="row">
  21. <view class="row__label">当前发布展示版本</view>
  22. <view class="row__value">{{presentationText}}</view>
  23. </view>
  24. <view class="row">
  25. <view class="row__label">当前发布内容包版本</view>
  26. <view class="row__value">{{contentBundleText}}</view>
  27. </view>
  28. </view>
  29. <view class="panel">
  30. <view class="panel__title">运行对象摘要</view>
  31. <view class="summary">当前阶段以前端已知信息预览,最终绑定以后端 `launch.runtime` 为准。</view>
  32. <view class="row">
  33. <view class="row__label">地点</view>
  34. <view class="row__value">{{runtimePlaceText}}</view>
  35. </view>
  36. <view class="row">
  37. <view class="row__label">地图</view>
  38. <view class="row__value">{{runtimeMapText}}</view>
  39. </view>
  40. <view class="row">
  41. <view class="row__label">赛道</view>
  42. <view class="row__value">{{runtimeVariantText}}</view>
  43. </view>
  44. <view class="row">
  45. <view class="row__label">RouteCode</view>
  46. <view class="row__value">{{runtimeRouteCodeText}}</view>
  47. </view>
  48. </view>
  49. <view class="panel" wx:if="{{showVariantSelector}}">
  50. <view class="panel__title">赛道选择</view>
  51. <view class="summary">当前活动要求手动指定赛道。这里的选择会随 launch 一起带给后端,最终绑定以后端返回为准。</view>
  52. <view wx:if="{{!selectableVariants.length}}" class="summary">{{variantSelectorEmptyText}}</view>
  53. <view wx:if="{{selectableVariants.length}}" class="variant-list">
  54. <view wx:for="{{selectableVariants}}" wx:key="id" class="variant-card {{item.selected ? 'variant-card--active' : ''}}" data-variant-id="{{item.id}}" bindtap="handleSelectVariant">
  55. <view class="variant-card__main">
  56. <view class="variant-card__title-row">
  57. <text class="variant-card__name">{{item.name}}</text>
  58. <text class="variant-card__badge" wx:if="{{item.selected}}">已选中</text>
  59. </view>
  60. <text class="variant-card__meta">{{item.routeCodeText}}</text>
  61. <text class="variant-card__meta">{{item.descriptionText}}</text>
  62. </view>
  63. </view>
  64. </view>
  65. </view>
  66. <view class="panel">
  67. <view class="panel__title">设备准备</view>
  68. <view class="summary">这一页现在负责局前设备准备。定位权限先在这里确认,心率带支持先连后进图,地图内仍保留局中快速重连入口。</view>
  69. <view class="row">
  70. <view class="row__label">定位状态</view>
  71. <view class="row__value">{{locationStatusText}}</view>
  72. </view>
  73. <view class="summary" wx:if="{{locationPermissionGranted && !locationBackgroundPermissionGranted}}">已完成前台定位授权;如果后续需要后台持续定位,请在系统设置中补齐后台权限。</view>
  74. <view class="actions">
  75. <button class="btn btn--secondary" bindtap="handleRequestLocationPermission">申请定位权限</button>
  76. <button class="btn btn--ghost" bindtap="handleOpenLocationSettings">打开系统设置</button>
  77. </view>
  78. <view class="row">
  79. <view class="row__label">心率带</view>
  80. <view class="row__value">{{heartRateStatusText}}</view>
  81. </view>
  82. <view class="row">
  83. <view class="row__label">当前设备</view>
  84. <view class="row__value">{{heartRateDeviceText}}</view>
  85. </view>
  86. <view class="row">
  87. <view class="row__label">扫描状态</view>
  88. <view class="row__value">{{heartRateScanText}}</view>
  89. </view>
  90. <view class="row">
  91. <view class="row__label">模拟源</view>
  92. <view class="row__value">{{mockSourceStatusText}}</view>
  93. </view>
  94. <view class="actions">
  95. <button class="btn btn--secondary" bindtap="handleOpenHeartRateDevicePicker">选择设备</button>
  96. <button class="btn btn--ghost" bindtap="handlePrepareHeartRateConnect">重新扫描</button>
  97. <button class="btn btn--ghost" bindtap="handlePrepareHeartRateDisconnect">断开连接</button>
  98. <button class="btn btn--ghost" bindtap="handlePrepareHeartRateClearPreferred">清除首选</button>
  99. </view>
  100. </view>
  101. <view class="panel">
  102. <view class="panel__title">开始比赛</view>
  103. <view class="summary">这一页先承担局前准备壳子,后面会继续接定位权限、心率带局前连接和设备检查。</view>
  104. <view class="actions">
  105. <button class="btn btn--secondary" bindtap="handleBack">返回活动页</button>
  106. <button class="btn btn--ghost" bindtap="handleRefresh">刷新</button>
  107. <button class="btn btn--primary" bindtap="handleLaunch" disabled="{{!canLaunch}}">进入地图</button>
  108. </view>
  109. </view>
  110. </view>
  111. <view wx:if="{{showHeartRateDevicePicker}}" class="picker-mask" bindtap="handleCloseHeartRateDevicePicker"></view>
  112. <view wx:if="{{showHeartRateDevicePicker}}" class="picker-sheet">
  113. <view class="picker-sheet__header">
  114. <view class="picker-sheet__title">选择心率带设备</view>
  115. <button class="picker-sheet__close" bindtap="handleCloseHeartRateDevicePicker">关闭</button>
  116. </view>
  117. <view class="summary">扫描状态:{{heartRateScanText}}</view>
  118. <view wx:if="{{!heartRateDiscoveredDevices.length}}" class="summary">当前还没有发现设备,可先点“重新扫描”。</view>
  119. <view wx:if="{{heartRateDiscoveredDevices.length}}" class="device-list">
  120. <view wx:for="{{heartRateDiscoveredDevices}}" wx:key="deviceId" class="device-card">
  121. <view class="device-card__main">
  122. <view class="device-card__title-row">
  123. <text class="device-card__name">{{item.name}}</text>
  124. <text class="device-card__badge" wx:if="{{item.preferred}}">首选</text>
  125. <text class="device-card__badge device-card__badge--active" wx:if="{{item.connected}}">已连接</text>
  126. </view>
  127. <text class="device-card__meta">{{item.rssiText}}</text>
  128. </view>
  129. <button class="btn {{item.connected ? 'btn--ghost' : 'btn--secondary'}} device-card__action" data-device-id="{{item.deviceId}}" bindtap="handlePrepareHeartRateDeviceConnect">{{item.connected ? '已连接' : '连接'}}</button>
  130. </view>
  131. </view>
  132. </view>
  133. </scroll-view>