2025-05-03 14:36:09 -04:00
|
|
|
<%= form_with model: import, class: "contents", data: { controller: "direct-upload", direct_upload_url_value: rails_direct_uploads_url } do |form| %>
|
2024-06-30 11:47:36 -04:00
|
|
|
<div class="form-control w-full">
|
2024-06-19 15:16:06 -04:00
|
|
|
<label class="label">
|
2024-03-15 18:27:31 -04:00
|
|
|
<span class="label-text">Select source</span>
|
2024-06-19 15:16:06 -04:00
|
|
|
</label>
|
2024-06-30 11:47:36 -04:00
|
|
|
<div class="grid grid-cols-1 sm:grid-cols-2 lg:grid-cols-3 gap-4">
|
|
|
|
|
<div class="card bordered shadow-lg p-3 hover:shadow-blue-500/50">
|
2024-06-19 15:16:06 -04:00
|
|
|
<div class="form-control">
|
|
|
|
|
<label class="label cursor-pointer space-x-3">
|
2024-06-30 11:57:13 -04:00
|
|
|
<%= form.radio_button :source, :google_semantic_history, class: "radio radio-primary" %>
|
2024-06-30 11:47:36 -04:00
|
|
|
<span class="label-text">Google Semantic History</span>
|
2024-06-19 15:16:06 -04:00
|
|
|
</label>
|
2024-06-30 11:47:36 -04:00
|
|
|
<p class="text-sm mt-2">JSON files from your Takeout/Location History/Semantic Location History/YEAR</p>
|
2024-06-19 15:16:06 -04:00
|
|
|
</div>
|
2024-06-30 11:47:36 -04:00
|
|
|
</div>
|
|
|
|
|
<div class="card bordered shadow-lg p-3 hover:shadow-blue-500/50">
|
|
|
|
|
<div class="form-control">
|
|
|
|
|
<label class="label cursor-pointer space-x-3">
|
2025-04-03 12:41:05 -04:00
|
|
|
<%= form.radio_button :source, :google_records, class: "radio radio-primary" %>
|
|
|
|
|
<span class="label-text">Google Records</span>
|
2024-06-30 11:47:36 -04:00
|
|
|
</label>
|
2025-04-03 12:41:05 -04:00
|
|
|
<p class="text-sm mt-2">The Records.json file from your Google Takeout</p>
|
2024-06-30 11:47:36 -04:00
|
|
|
</div>
|
|
|
|
|
</div>
|
2024-09-02 16:33:54 -04:00
|
|
|
<div class="card bordered shadow-lg p-3 hover:shadow-blue-500/50">
|
|
|
|
|
<div class="form-control">
|
|
|
|
|
<label class="label cursor-pointer space-x-3">
|
2025-04-03 12:41:05 -04:00
|
|
|
<%= form.radio_button :source, :google_phone_takeout, class: "radio radio-primary" %>
|
|
|
|
|
<span class="label-text">Google Phone Takeout</span>
|
2024-09-02 16:33:54 -04:00
|
|
|
</label>
|
2025-04-03 12:41:05 -04:00
|
|
|
<p class="text-sm mt-2">A JSON file you received after your request for Takeout from your mobile device</p>
|
2024-09-02 16:33:54 -04:00
|
|
|
</div>
|
|
|
|
|
</div>
|
2024-06-30 11:47:36 -04:00
|
|
|
<div class="card bordered shadow-lg p-3 hover:shadow-blue-500/50">
|
|
|
|
|
<div class="form-control">
|
|
|
|
|
<label class="label cursor-pointer space-x-3">
|
2025-04-03 12:41:05 -04:00
|
|
|
<%= form.radio_button :source, :owntracks, class: "radio radio-primary" %>
|
|
|
|
|
<span class="label-text">Owntracks</span>
|
2024-06-30 11:47:36 -04:00
|
|
|
</label>
|
2025-04-03 12:41:05 -04:00
|
|
|
<p class="text-sm mt-2">A .REC file you could find in your volumes/owntracks-recorder/store/rec/USER/TOPIC directory</p>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
<div class="card bordered shadow-lg p-3 hover:shadow-blue-500/50">
|
|
|
|
|
<div class="form-control">
|
|
|
|
|
<label class="label cursor-pointer space-x-3">
|
|
|
|
|
<%= form.radio_button :source, :geojson, class: "radio radio-primary" %>
|
|
|
|
|
<span class="label-text">GeoJSON</span>
|
|
|
|
|
</label>
|
|
|
|
|
<p class="text-sm mt-2">A valid GeoJSON file. For example, a file, exported from a Dawarich instance</p>
|
2024-06-30 11:47:36 -04:00
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
<div class="card bordered shadow-lg p-3 hover:shadow-blue-500/50">
|
|
|
|
|
<div class="form-control">
|
|
|
|
|
<label class="label cursor-pointer space-x-3">
|
2024-06-30 11:57:13 -04:00
|
|
|
<%= form.radio_button :source, :gpx, class: "radio radio-primary" %>
|
2024-06-30 11:47:36 -04:00
|
|
|
<span class="label-text">GPX</span>
|
|
|
|
|
</label>
|
|
|
|
|
<p class="text-sm mt-2">GPX track file</p>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
2024-03-15 18:27:31 -04:00
|
|
|
</div>
|
2024-06-19 15:16:06 -04:00
|
|
|
</div>
|
2024-03-15 18:27:31 -04:00
|
|
|
|
|
|
|
|
<label class="form-control w-full max-w-xs my-5">
|
|
|
|
|
<div class="label">
|
2024-06-30 11:47:36 -04:00
|
|
|
<span class="label-text">Select one or multiple files</span>
|
2024-03-15 18:27:31 -04:00
|
|
|
</div>
|
2025-05-03 14:36:09 -04:00
|
|
|
<%= form.file_field :files,
|
|
|
|
|
multiple: true,
|
|
|
|
|
class: "file-input file-input-bordered w-full max-w-xs",
|
|
|
|
|
data: { direct_upload_target: "input" } %>
|
2024-03-15 18:27:31 -04:00
|
|
|
</label>
|
|
|
|
|
|
|
|
|
|
<div class="inline">
|
2025-05-03 14:36:09 -04:00
|
|
|
<%= form.submit class: "rounded-lg py-3 px-5 bg-blue-600 text-white inline-block font-medium cursor-pointer",
|
|
|
|
|
data: { direct_upload_target: "submit" } %>
|
2024-03-15 18:27:31 -04:00
|
|
|
</div>
|
|
|
|
|
<% end %>
|