????

Your IP : 3.21.43.104


Current Path : /proc/self/cwd/wp-content/plugins/presto-player/src/admin/blocks/shared/components/
Upload File :
Current File : //proc/self/cwd/wp-content/plugins/presto-player/src/admin/blocks/shared/components/ColorPopup.js

/** @jsx jsx */
const { ColorPicker, ColorIndicator, Popover, Button, Flex } = wp.components;
const { useState, useEffect } = wp.element;
const { __ } = wp.i18n;
import { css, jsx } from "@emotion/core";

export default ({ color, setColor, onFocus }) => {
  const [open, setOpen] = useState(false);
  const [original, setOriginal] = useState(color);

  useEffect(() => {
    if (open && color) {
      setOriginal(color);
    }
  }, [open]);

  return (
    <span>
      <ColorIndicator
        css={{ width: "25px", height: "25px", borderRadius: "9999px" }}
        colorValue={color}
        onClick={() => {
          setOpen(!open);
          onFocus && onFocus();
        }}
      />
      {!!open && (
        <Popover
          position="bottom left"
          focusOnMount
          onFocusOutside={(e) => {
            setOpen(false);
          }}
          css={css`
            .components-color-picker,
            .react-colorful {
              width: 100%;
            }
          `}
        >
          <ColorPicker
            color={color || ""}
            onChangeComplete={(value) => value?.hex && setColor(value)}
            disableAlpha
          />
          <div
            css={{
              display: "flex",
              alignItems: "center",
              justifyContent: "space-between",
              padding: "10px",
            }}
          >
            <Button
              css={{ margin: "0 5px" }}
              isTertiary
              onClick={() => {
                setColor({ hex: null });
                setOpen(false);
              }}
            >
              {__("Reset", "presto-player")}
            </Button>
            <div
              css={{
                display: "flex",
                justifyContent: "flex-end",
                padding: "10px",
              }}
            >
              <Button
                css={{ margin: "0 5px" }}
                isTertiary
                onClick={() => {
                  setColor({ hex: original });
                  setOpen(false);
                }}
              >
                {__("Cancel", "presto-player")}
              </Button>
              <Button isPrimary onClick={() => setOpen(false)}>
                {__("Apply", "presto-player")}
              </Button>
            </div>
          </div>
        </Popover>
      )}
    </span>
  );
};