| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556 |
- (ns frontend.components.commit
- (:require [rum.core :as rum]
- [frontend.util :as util :refer-macros [profile]]
- [frontend.handler.repo :as repo-handler]
- [frontend.state :as state]
- [frontend.mixins :as mixins]
- [frontend.handler.notification :as notification]
- [promesa.core :as p]
- [goog.dom :as gdom]
- [goog.object :as gobj]))
- (defn commit-and-push!
- []
- (let [value (gobj/get (gdom/getElement "commit-message") "value")]
- (when (and value (>= (count value) 1))
- (-> (repo-handler/git-commit-and-push! value)
- (p/catch (fn [error]
- (notification/show! error :error false))))
- (state/close-modal!))))
- (rum/defcs add-commit-message <
- {:did-update (fn [state]
- (when-let [input (gdom/getElement "commit-message")]
- (.focus input)
- (util/move-cursor-to-end input))
- state)}
- (mixins/event-mixin
- (fn [state]
- (mixins/on-enter state
- :node (gdom/getElement "commit-message")
- :on-enter (fn []
- (commit-and-push!)))))
- [state close-fn]
- (when-let [repo (state/sub :git/current-repo)]
- [:div
- [:div.sm:flex.sm:items-start
- [:div.mt-3.text-center.sm:mt-0.sm:text-left.mb-2
- [:h3#modal-headline.text-lg.leading-6.font-medium.text-gray-900
- "Your commit message:"]]]
- [:input#commit-message.form-input.block.w-full.sm:text-sm.sm:leading-5.my-2
- {:style {:color "#000"}
- :auto-focus true
- :default-value ""}]
- [:div.mt-5.sm:mt-4.sm:flex.sm:flex-row-reverse
- [:span.flex.w-full.rounded-md.shadow-sm.sm:ml-3.sm:w-auto
- [:button.inline-flex.justify-center.w-full.rounded-md.border.border-transparent.px-4.py-2.bg-indigo-600.text-base.leading-6.font-medium.text-white.shadow-sm.hover:bg-indigo-500.focus:outline-none.focus:border-indigo-700.focus:shadow-outline-indigo.transition.ease-in-out.duration-150.sm:text-sm.sm:leading-5
- {:type "button"
- :on-click commit-and-push!}
- "Commit and push!"]]
- [:span.mt-3.flex.w-full.rounded-md.shadow-sm.sm:mt-0.sm:w-auto
- [:button.inline-flex.justify-center.w-full.rounded-md.border.border-gray-300.px-4.py-2.bg-white.text-base.leading-6.font-medium.text-gray-700.shadow-sm.hover:text-gray-500.focus:outline-none.focus:border-blue-300.focus:shadow-outline-blue.transition.ease-in-out.duration-150.sm:text-sm.sm:leading-5
- {:type "button"
- :on-click close-fn}
- "Cancel"]]]]))
|