????

Your IP : 3.21.43.104


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

import { __ } from "@wordpress/i18n";

import {
  Button,
  TextControl,
  Placeholder,
  Flex,
  FlexBlock,
  ExternalLink,
  Spinner,
  FlexItem,
  Notice,
} from "@wordpress/components";
import { useEffect } from "@wordpress/element";

import useStorageConnection from "./useStorageConnection";
import useStreamConnection from "./useStreamConnection";

export default ({ onRefetch, type, autoSubmit }) => {
  const {
    saveKey,
    apikey,
    setApikey,
    saveMessage,
    saving,
    totalSteps,
    step,
    error,
  } =
    type === "stream"
      ? useStreamConnection(onRefetch)
      : useStorageConnection(onRefetch);

  useEffect(() => {
    if (autoSubmit) {
      saveKey();
    }
  }, [autoSubmit]);

  return (
    <Placeholder
      label={__("Bunny.net Video", "presto-player")}
      instructions={__(
        "Enter your Bunny.net API key, which can be found on your Bunny CDN Account page.",
        "presto-player"
      )}
    >
      {saving ? (
        <Flex>
          <FlexItem>
            <Spinner />
          </FlexItem>
          <FlexBlock>
            {saveMessage}
            <progress
              className="presto-progress"
              max={totalSteps}
              value={step}
              style={{ width: "100%" }}
            ></progress>
          </FlexBlock>
        </Flex>
      ) : (
        <form
          onSubmit={(e) => {
            e.preventDefault();
            saveKey();
          }}
        >
          {error && (
            <Flex style={{ width: "100%" }}>
              <FlexBlock>
                <Notice status="error" isDismissible={false}>
                  {error}
                </Notice>
              </FlexBlock>
            </Flex>
          )}
          <Flex style={{ width: "100%", maxWidth: "400px" }}>
            <FlexBlock>
              <TextControl
                value={apikey}
                onChange={(apikey) => setApikey(apikey)}
                className={"presto-link-placeholder-input"}
                type="password"
                autoComplete="off"
                placeholder={__("Your Bunny.net API Key", "presto-player")}
                required
              />
            </FlexBlock>
            <FlexItem>
              <Button isPrimary style={{ marginBottom: "8px" }} type="submit">
                {__("Next", "presto-player")} &rarr;
              </Button>
            </FlexItem>
          </Flex>
        </form>
      )}
    </Placeholder>
  );
};