0
Fork 0
mirror of https://github.com/penpot/penpot.git synced 2025-01-26 00:19:07 -05:00

Changed export modal progress

This commit is contained in:
alonso.torres 2021-07-06 18:04:49 +02:00
parent 60009476d6
commit 84cf63d1ba
7 changed files with 132 additions and 60 deletions

View file

@ -215,6 +215,7 @@
background-color: $color-white; background-color: $color-white;
border: 1px solid $color-gray-20; border: 1px solid $color-gray-20;
width: 30rem; width: 30rem;
min-height: 14rem;
p { p {
font-size: $fs14; font-size: $fs14;
@ -276,10 +277,6 @@
.modal-content { .modal-content {
padding: 1rem; padding: 1rem;
} }
}
.import-dialog {
min-height: 215px;
svg { svg {
max-width: 18px; max-width: 18px;
@ -451,8 +448,6 @@
} }
.export-dialog { .export-dialog {
min-height: 24rem;
.export-option { .export-option {
border-radius: 4px; border-radius: 4px;
border: 1px solid $color-gray-10; border: 1px solid $color-gray-10;

View file

@ -11,6 +11,7 @@
[app.main.store :as st] [app.main.store :as st]
[app.main.ui.icons :as i] [app.main.ui.icons :as i]
[app.main.worker :as uw] [app.main.worker :as uw]
[app.util.data :refer [classnames]]
[app.util.dom :as dom] [app.util.dom :as dom]
[app.util.i18n :as i18n :refer [tr]] [app.util.i18n :as i18n :refer [tr]]
[beicon.core :as rx] [beicon.core :as rx]
@ -18,12 +19,60 @@
(def ^:const options [:all :merge :detach]) (def ^:const options [:all :merge :detach])
(mf/defc export-entry
[{:keys [file]}]
[:div.file-entry
{:class (classnames :loading (:loading? file)
:success (:export-success? file)
:error (:export-error? file))}
[:div.file-name
[:div.file-icon
(cond (:export-success? file) i/tick
(:export-error? file) i/close
(:loading? file) i/loader-pencil)]
[:div.file-name-label (:name file)]]])
(defn mark-file-error [files file-id]
(->> files
(mapv #(cond-> %
(= file-id (:id %))
(assoc :export-error? true
:loading? false)))))
(defn mark-file-success [files file-id]
(->> files
(mapv #(cond-> %
(= file-id (:id %))
(assoc :export-success? true
:loading? false)))))
(mf/defc export-dialog (mf/defc export-dialog
{::mf/register modal/components {::mf/register modal/components
::mf/register-as :export} ::mf/register-as :export}
[{:keys [team-id files]}] [{:keys [team-id files has-libraries?]}]
(let [selected-option (mf/use-state :all) (let [state (mf/use-state {:status :prepare
:files (->> files (mapv #(assoc % :loading? true)))})
selected-option (mf/use-state :all)
start-export
(fn []
(swap! state assoc :status :exporting)
(->> (uw/ask-many!
{:cmd :export-file
:team-id team-id
:export-type @selected-option
:files (->> files (mapv :id))})
(rx/delay-emit 1000)
(rx/subs
(fn [msg]
(when (= :error (:type msg))
(swap! state update :files mark-file-error (:file-id msg)))
(when (= :finish (:type msg))
(swap! state update :files mark-file-success (:file-id msg))
(dom/trigger-download-uri (:filename msg) (:mtype msg) (:uri msg)))))))
cancel-fn cancel-fn
(mf/use-callback (mf/use-callback
(fn [event] (fn [event]
@ -35,24 +84,19 @@
(mf/deps @selected-option) (mf/deps @selected-option)
(fn [event] (fn [event]
(dom/prevent-default event) (dom/prevent-default event)
(start-export)))
(->> (uw/ask-many!
{:cmd :export-file
:team-id team-id
:export-type @selected-option
:files files})
(rx/subs
(fn [msg]
(when (= :finish (:type msg))
(dom/trigger-download-uri (:filename msg) (:mtype msg) (:uri msg))))))
(st/emit! (modal/hide))))
on-change-handler on-change-handler
(mf/use-callback (mf/use-callback
(fn [_ type] (fn [_ type]
(reset! selected-option type)))] (reset! selected-option type)))]
(mf/use-effect
(fn []
(when-not has-libraries?
;; Start download automaticaly
(start-export))))
[:div.modal-overlay [:div.modal-overlay
[:div.modal-container.export-dialog [:div.modal-container.export-dialog
[:div.modal-header [:div.modal-header
@ -62,31 +106,49 @@
[:div.modal-close-button [:div.modal-close-button
{:on-click cancel-fn} i/close]] {:on-click cancel-fn} i/close]]
[:div.modal-content (cond
[:p.explain (tr "dashboard.export.explain")] (= (:status @state) :prepare)
[:p.detail (tr "dashboard.export.detail")] [:*
[:div.modal-content
[:p.explain (tr "dashboard.export.explain")]
[:p.detail (tr "dashboard.export.detail")]
(for [type [:all :merge :detach]] (for [type [:all :merge :detach]]
(let [selected? (= @selected-option type)] (let [selected? (= @selected-option type)]
[:div.export-option {:class (when selected? "selected")} [:div.export-option {:class (when selected? "selected")}
[:label.option-container [:label.option-container
[:h3 (tr (str "dashboard.export.options." (d/name type) ".title"))] [:h3 (tr (str "dashboard.export.options." (d/name type) ".title"))]
[:p (tr (str "dashboard.export.options." (d/name type) ".message"))] [:p (tr (str "dashboard.export.options." (d/name type) ".message"))]
[:input {:type "radio" [:input {:type "radio"
:checked selected? :checked selected?
:on-change #(on-change-handler % type) :on-change #(on-change-handler % type)
:name "export-option"}] :name "export-option"}]
[:span {:class "option-radio-check"}]]]))] [:span {:class "option-radio-check"}]]]))]
[:div.modal-footer [:div.modal-footer
[:div.action-buttons [:div.action-buttons
[:input.cancel-button [:input.cancel-button
{:type "button" {:type "button"
:value (tr "labels.cancel") :value (tr "labels.cancel")
:on-click cancel-fn}] :on-click cancel-fn}]
[:input.accept-button [:input.accept-button
{:class "primary" {:class "primary"
:type "button" :type "button"
:value (tr "labels.export") :value (tr "labels.continue")
:on-click accept-fn}]]]]])) :on-click accept-fn}]]]]
(= (:status @state) :exporting)
[:*
[:div.modal-content
(for [file (:files @state)]
[:& export-entry {:file file}])]
[:div.modal-footer
[:div.action-buttons
[:input.accept-button
{:class "primary"
:type "button"
:value (tr "labels.close")
:disabled (->> @state :files (some :loading?))
:on-click cancel-fn}]]]])]]))

View file

@ -171,7 +171,8 @@
(modal/show (modal/show
{:type :export {:type :export
:team-id current-team-id :team-id current-team-id
:files (->> files (mapv :id))})))))))] :has-libraries? (->> files (some :has-libraries?))
:files files})))))))]
(mf/use-effect (mf/use-effect
(fn [] (fn []

View file

@ -153,7 +153,7 @@
(modal/show (modal/show
{:type :export {:type :export
:team-id team-id :team-id team-id
:files (->> files (mapv :id))})))))))] :files files})))))))]
(mf/use-effect (mf/use-effect
(mf/deps @editing?) (mf/deps @editing?)

View file

@ -450,14 +450,22 @@
[{:keys [team-id files export-type] :as message}] [{:keys [team-id files export-type] :as message}]
(->> (rx/from files) (->> (rx/from files)
(rx/mapcat #(export-file team-id % export-type)) (rx/mapcat
(rx/map (fn [file]
(fn [value] (->> (export-file team-id file export-type)
(if (contains? value :type) (rx/map
value (fn [value]
(let [[file export-blob] value] (if (contains? value :type)
{:type :finish value
:filename (:name file) (let [[file export-blob] value]
:mtype "application/penpot" {:type :finish
:description "Penpot export (*.penpot)" :file-id (:id file)
:uri (dom/create-uri export-blob)})))))) :filename (:name file)
:mtype "application/penpot"
:description "Penpot export (*.penpot)"
:uri (dom/create-uri export-blob)}))))
(rx/catch
(fn [err]
(rx/of {:type :error
:error (str err)
:file-id file}))))))))

View file

@ -855,6 +855,9 @@ msgstr "You are seeing version %s"
msgid "labels.accept" msgid "labels.accept"
msgstr "Accept" msgstr "Accept"
msgid "labels.close"
msgstr "Close"
msgid "labels.add-custom-font" msgid "labels.add-custom-font"
msgstr "Add custom font" msgstr "Add custom font"
@ -2746,4 +2749,4 @@ msgid "workspace.updates.update"
msgstr "Update" msgstr "Update"
msgid "workspace.viewport.click-to-close-path" msgid "workspace.viewport.click-to-close-path"
msgstr "Click to close the path" msgstr "Click to close the path"

View file

@ -855,6 +855,9 @@ msgstr "Estás viendo la versión %s"
msgid "labels.accept" msgid "labels.accept"
msgstr "Aceptar" msgstr "Aceptar"
msgid "labels.close"
msgstr "Cerrar"
msgid "labels.add-custom-font" msgid "labels.add-custom-font"
msgstr "Añadir fuentes personalizada" msgstr "Añadir fuentes personalizada"
@ -2742,4 +2745,4 @@ msgid "workspace.updates.update"
msgstr "Actualizar" msgstr "Actualizar"
msgid "workspace.viewport.click-to-close-path" msgid "workspace.viewport.click-to-close-path"
msgstr "Pulsar para cerrar la ruta" msgstr "Pulsar para cerrar la ruta"