All files / app/features/communities NewGuideForm.tsx

0% Statements 0/25
0% Branches 0/5
0% Functions 0/5
0% Lines 0/24

Press n or j to go to the next uncovered block, b, p or k for the previous block.

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109                                                                                                                                                                                                                         
import Alert from "components/Alert";
import Button from "components/Button";
import CenteredSpinner from "components/CenteredSpinner/CenteredSpinner";
import EditLocationMap from "components/EditLocationMap";
import TextField from "components/TextField";
import ProfileMarkdownInput from "features/profile/ProfileMarkdownInput";
import { RpcError } from "grpc-web";
import { useRouter } from "next/router";
import { Page, PageType } from "proto/pages_pb";
import React from "react";
import { Controller, useForm } from "react-hook-form";
import { useMutation } from "react-query";
import { routeToGuide, routeToPlace } from "routes";
import { service } from "service";
 
type NewGuideInputs = {
  title: string;
  content: string;
  address: string;
  lat?: number;
  lng?: number;
};
 
export default function NewGuideForm() {
  const {
    control,
    register,
    handleSubmit,
    setValue,
 
    formState: { errors },
  } = useForm<NewGuideInputs>({
    mode: "onBlur",
    shouldUnregister: false,
  });
 
  const router = useRouter();
 
  const {
    mutate: createGuide,
    isLoading: isCreateLoading,
    error: createError,
  } = useMutation<Page.AsObject, RpcError, NewGuideInputs>(
    ({ title, content, address, lat, lng }: NewGuideInputs) =>
      // TODO: parent community ID
      service.pages.createGuide(title, content, 1, address, lat, lng),
    {
      onSuccess: (page) => {
        router.push(
          page.type === PageType.PAGE_TYPE_PLACE
            ? routeToPlace(page.pageId, page.slug)
            : routeToGuide(page.pageId, page.slug)
        );
      },
    }
  );
 
  const onSubmit = handleSubmit((data: NewGuideInputs) => createGuide(data));
 
  return (
    <>
      {createError && <Alert severity="error">{createError?.message}</Alert>}
      {isCreateLoading ? (
        <CenteredSpinner />
      ) : (
        <form onSubmit={onSubmit}>
          <TextField
            id="new-page-title"
            {...register("title", {
              required: "Enter a page title",
            })}
            label="Page Title"
            helperText={errors?.title?.message}
          />
          <ProfileMarkdownInput
            id="content"
            name="content"
            label="Page content"
            control={control}
          />
 
          <Controller
            name="address"
            control={control}
            render={({ field }) => (
              <EditLocationMap
                {...field}
                exact
                updateLocation={(location) => {
                  Iif (location) {
                    // TODO: error handling
                    setValue("address", location.address);
                    setValue("lat", location.lat);
                    setValue("lng", location.lng);
                  }
                }}
              />
            )}
          />
 
          <Button onClick={onSubmit} loading={isCreateLoading}>
            Create page
          </Button>
        </form>
      )}
    </>
  );
}