module Gargantext.Components.NgramsTable.SyncResetButton where import Gargantext.Prelude import Effect.Aff (Aff) import Effect.Class (liftEffect) import FFI.Simple.Functions (delay) import Gargantext.Components.Bootstrap as B import Gargantext.Components.Bootstrap.Types (ButtonVariant(..), ComponentStatus(..), Variant(..)) import Gargantext.Core.NgramsTable.Types (CoreAction(..), CoreDispatch, NgramsTablePatch) import Gargantext.Utils.Reactix as R2 import Reactix as R import Reactix.DOM.HTML as H import Toestand as T here :: R2.Here here = R2.here "Gargantext.Components.NgramsTable.SyncResetButton" -- | Reset Button type SyncResetButtonsProps = ( afterSync :: Unit -> Aff Unit , ngramsLocalPatch :: NgramsTablePatch , performAction :: CoreDispatch ) syncResetButtons :: Record SyncResetButtonsProps -> R.Element syncResetButtons p = R.createElement syncResetButtonsCpt p [] syncResetButtonsCpt :: R.Component SyncResetButtonsProps syncResetButtonsCpt = here.component "syncResetButtons" cpt where cpt { afterSync, ngramsLocalPatch, performAction } _ = do synchronizing <- T.useBox false synchronizing' <- T.useLive T.unequal synchronizing let hasChanges = ngramsLocalPatch /= mempty statusReset _ true = Disabled statusReset false _ = Disabled statusReset _ _ = Enabled statusSync _ true = Deferred statusSync false _ = Disabled statusSync _ _ = Enabled resetClick _ = do performAction ResetPatches synchronizeClick _ = delay unit $ \_ -> do T.write_ true synchronizing performAction $ Synchronize { afterSync: newAfterSync } newAfterSync x = do afterSync x liftEffect $ T.write_ false synchronizing pure $ B.wad [ "d-flex" ] [ B.button { variant: ButtonVariant Light , callback: resetClick , status: statusReset hasChanges synchronizing' } [ H.text "Reset" ] , B.wad_ [ "mr-1", "d-inline-block" ] , B.button { variant: ButtonVariant Primary , callback: synchronizeClick , status: statusSync hasChanges synchronizing' } [ H.text "Sync" ] ]