confirm_page.html 2.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859
  1. {% extends "layout.html" %}
  2. {% block title %}确认页码 - 家谱管理系统{% endblock %}
  3. {% block content %}
  4. <div class="row justify-content-center">
  5. <div class="col-md-8">
  6. <div class="card shadow">
  7. <div class="card-header bg-warning">
  8. <h5 class="mb-0 text-dark"><i class="bi bi-exclamation-triangle me-2"></i>未识别到页码</h5>
  9. </div>
  10. <div class="card-body p-4">
  11. <div class="row">
  12. <div class="col-md-6 border-end">
  13. <h6>预览扫描件</h6>
  14. <div class="text-center bg-light p-2 rounded" style="height: 300px; overflow: hidden;">
  15. <img src="{{ oss_url }}" class="img-fluid" style="max-height: 100%;" alt="预览">
  16. </div>
  17. </div>
  18. <div class="col-md-6 ps-4">
  19. <h6>请手动输入页码</h6>
  20. <p class="text-muted small">系统未能自动从图片中解析出页码,请对照预览图手动录入。</p>
  21. <form action="{{ url_for('save_upload') }}" method="POST">
  22. <input type="hidden" name="filename" value="{{ filename }}">
  23. <input type="hidden" name="oss_url" value="{{ oss_url }}">
  24. <div class="mb-3">
  25. <label class="form-label fw-bold">页码</label>
  26. <input type="number" name="page_number" id="manualPageInput" class="form-control form-control-lg" required>
  27. </div>
  28. <div class="alert alert-info py-2 small">
  29. <i class="bi bi-lightbulb me-1"></i> 快捷提示:
  30. <button type="button" class="btn btn-link btn-sm p-0 mb-1" onclick="setPage({{ suggested_page }})">
  31. 是第 <strong>{{ suggested_page }}</strong> 页吗?
  32. </button>
  33. <br>
  34. <span class="text-muted">(根据数据库中上一页自动推算)</span>
  35. </div>
  36. <div class="d-grid gap-2">
  37. <button type="submit" class="btn btn-primary">确认并保存</button>
  38. <a href="{{ url_for('index') }}" class="btn btn-light">稍后录入</a>
  39. </div>
  40. </form>
  41. </div>
  42. </div>
  43. </div>
  44. </div>
  45. </div>
  46. </div>
  47. <script>
  48. function setPage(val) {
  49. document.getElementById('manualPageInput').value = val;
  50. }
  51. </script>
  52. {% endblock %}