Skip to content

Commit

Permalink
4440-refactor-code-any-type-in-form-events-and-inputs (#4441)
Browse files Browse the repository at this point in the history
* 4440-refactor-code-any-type-in-form-events-and-inputs

* 4440-refactor-code-any-type-in-form-events-and-inputs

* 4440-refactor-code-any-type-in-form-events-and-inputs

* 4440-refactor-code-any-type-in-form-events-and-inputs

* 4440-refactor-code-any-type-in-form-events-and-inputs

* Create warm-files-reflect.md

---------

Co-authored-by: Patryk Andrzejewski <vox3r69@gmail.com>
  • Loading branch information
HigorSantiago and andrzejewsky authored Nov 21, 2023
1 parent 07c6b70 commit b5d5740
Show file tree
Hide file tree
Showing 18 changed files with 93 additions and 37 deletions.
5 changes: 5 additions & 0 deletions .changeset/warm-files-reflect.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
---
"saleor-dashboard": patch
---

Fix typing for form events
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,9 @@ const SearchInput: React.FC<SearchInputProps> = props => {
return (
<Debounce debounceFn={onSearchChange} time={500}>
{debounceSearchChange => {
const handleSearchChange = (event: React.ChangeEvent<any>) => {
const handleSearchChange = (
event: React.ChangeEvent<HTMLInputElement>,
) => {
const value = event.target.value;
setSearch(value);
debounceSearchChange(value);
Expand Down
4 changes: 3 additions & 1 deletion src/components/Datagrid/ColumnPicker/ColumnPickerSearch.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -25,7 +25,9 @@ export const ColumnPickerSearch: React.FC<ColumnPickerSearchProps> = ({
time={500}
>
{debounceSearchChange => {
const handleSearchChange = (event: React.ChangeEvent<any>) => {
const handleSearchChange = (
event: React.ChangeEvent<HTMLInputElement>,
) => {
const value = event.target.value ?? "";
setQuery(value);
debounceSearchChange(value);
Expand Down
5 changes: 4 additions & 1 deletion src/components/Form/Form.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -41,7 +41,10 @@ function Form<TData, Terrors>({
mergeData,
});

function handleSubmit(event?: React.FormEvent<any>, cb?: () => void) {
function handleSubmit(
event?: React.FormEvent<HTMLFormElement>,
cb?: () => void,
) {
const { reset, submit } = renderProps;

if (event) {
Expand Down
4 changes: 3 additions & 1 deletion src/components/SearchBar/SearchInput.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -33,7 +33,9 @@ const SearchInput: React.FC<SearchInputProps> = props => {
return (
<Debounce debounceFn={onSearchChange} time={500}>
{debounceSearchChange => {
const handleSearchChange = (event: React.ChangeEvent<any>) => {
const handleSearchChange = (
event: React.ChangeEvent<HTMLInputElement>,
) => {
const value = event.target.value;
setSearch(value);
debounceSearchChange(value);
Expand Down
2 changes: 1 addition & 1 deletion src/components/SeoForm/SeoForm.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -71,7 +71,7 @@ export const SeoForm: React.FC<SeoFormProps> = props => {
: getPageErrorMessage(error as PageErrorFragment, intl);
};

const handleSlugChange = (event: React.ChangeEvent<any>) => {
const handleSlugChange = (event: React.ChangeEvent<HTMLInputElement>) => {
const { value } = event.target;

if (value === "" || SLUG_REGEX.test(value)) {
Expand Down
16 changes: 12 additions & 4 deletions src/custom-apps/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,14 @@ import CustomAppListView from "./views/CustomAppList";
import CustomAppWebhookCreateView from "./views/CustomAppWebhookCreate";
import CustomAppWebhookDetailsView from "./views/CustomAppWebhookDetails";

interface MatchParams {
appId?: string;
}

interface MatchParamsWebhookDetails {
id?: string;
}

const CustomAppList: React.FC<RouteComponentProps> = () => {
const qs = parseQs(location.search.substr(1));
const params: CustomAppListUrlQueryParams = qs;
Expand Down Expand Up @@ -52,7 +60,7 @@ const CustomAppDetails: React.FC<CustomAppDetailsProps> = ({
);
};

const CustomAppWebhookCreate: React.FC<RouteComponentProps<any>> = ({
const CustomAppWebhookCreate: React.FC<RouteComponentProps<MatchParams>> = ({
match,
}) => {
const appId = match.params.appId;
Expand All @@ -64,9 +72,9 @@ const CustomAppWebhookCreate: React.FC<RouteComponentProps<any>> = ({
return <CustomAppWebhookCreateView appId={decodeURIComponent(appId)} />;
};

const CustomAppWebhookDetails: React.FC<RouteComponentProps<any>> = ({
match,
}) => {
const CustomAppWebhookDetails: React.FC<
RouteComponentProps<MatchParamsWebhookDetails>
> = ({ match }) => {
const id = match.params.id;

if (!id) {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -33,7 +33,7 @@ const GiftCardCustomerSelectField: React.FC<
label: getFullName({ firstName, lastName }),
}));

const handleSelect = (event: React.ChangeEvent<any>) => {
const handleSelect = (event: React.ChangeEvent<HTMLInputElement>) => {
const value = event.target.value;
const label = choices?.find(category => category.value === value)?.label;

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -150,8 +150,8 @@ const GiftCardResendCodeDialog: React.FC<DialogProps> = ({ open, onClose }) => {
name="differentMailConsent"
label={intl.formatMessage(messages.consentCheckboxLabel)}
checked={consentSelected}
onChange={(event: React.ChangeEvent<any>) =>
setConsentSelected(event.target.value)
onChange={(event: React.ChangeEvent<HTMLInputElement>) =>
setConsentSelected(!!event.target.value)
}
/>
<VerticalSpacer />
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -208,7 +208,7 @@ const MenuItemDialog: React.FC<MenuItemDialogProps> = ({
onQueryChange(query);
};

const handleSelectChange = (event: React.ChangeEvent<any>) => {
const handleSelectChange = (event: React.ChangeEvent<HTMLInputElement>) => {
const value = event.target.value;
const menuItemData = getMenuItemData(value);

Expand Down
4 changes: 3 additions & 1 deletion src/orders/components/OrderCustomer/OrderCustomer.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -122,7 +122,9 @@ const OrderCustomer: React.FC<OrderCustomerProps> = props => {
) : isInEditMode && canEditCustomer ? (
<Form confirmLeave initial={{ query: "" }}>
{({ change, data }) => {
const handleChange = (event: React.ChangeEvent<any>) => {
const handleChange = (
event: React.ChangeEvent<HTMLInputElement>,
) => {
change(event);
const value = event.target.value;

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -117,7 +117,7 @@ const OrderGrantRefundPage: React.FC<OrderGrantRefundPageProps> = ({

const currency = order?.total?.gross?.currency ?? "";

const handleSubmit = (e: React.FormEvent<any>) => {
const handleSubmit = (e: React.FormEvent<HTMLFormElement>) => {
e.stopPropagation();
e.preventDefault();
submit();
Expand Down
30 changes: 22 additions & 8 deletions src/orders/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -35,6 +35,10 @@ import OrderReturnComponent from "./views/OrderReturn";
import OrderSendRefundComponent from "./views/OrderSendRefund";
import OrderSettings from "./views/OrderSettings";

interface MatchParams {
id?: string;
}

const OrderList: React.FC<RouteComponentProps<any>> = ({ location }) => {
const qs = parseQs(location.search.substr(1)) as any;
const params: OrderListUrlQueryParams = asSortParams(
Expand Down Expand Up @@ -82,20 +86,30 @@ const OrderFulfill: React.FC<RouteComponentProps<any>> = ({
);
};

const OrderPaymentRefund: React.FC<RouteComponentProps<any>> = ({ match }) => (
<OrderRefundComponent orderId={decodeURIComponent(match.params.id)} />
const OrderPaymentRefund: React.FC<RouteComponentProps<MatchParams>> = ({
match,
}) => (
<OrderRefundComponent orderId={decodeURIComponent(match.params.id ?? "")} />
);

const OrderSendRefund: React.FC<RouteComponentProps<any>> = ({ match }) => (
<OrderSendRefundComponent orderId={decodeURIComponent(match.params.id)} />
const OrderSendRefund: React.FC<RouteComponentProps<MatchParams>> = ({
match,
}) => (
<OrderSendRefundComponent
orderId={decodeURIComponent(match.params.id ?? "")}
/>
);

const OrderReturn: React.FC<RouteComponentProps<any>> = ({ match }) => (
<OrderReturnComponent orderId={decodeURIComponent(match.params.id)} />
const OrderReturn: React.FC<RouteComponentProps<MatchParams>> = ({ match }) => (
<OrderReturnComponent orderId={decodeURIComponent(match.params.id ?? "")} />
);

const OrderGrantRefund: React.FC<RouteComponentProps<any>> = ({ match }) => (
<OrderGrantRefundComponent orderId={decodeURIComponent(match.params.id)} />
const OrderGrantRefund: React.FC<RouteComponentProps<MatchParams>> = ({
match,
}) => (
<OrderGrantRefundComponent
orderId={decodeURIComponent(match.params.id ?? "")}
/>
);

const OrderGrantRefundEdit: React.FC<RouteComponentProps<any>> = ({
Expand Down
8 changes: 3 additions & 5 deletions src/orders/views/OrderDetails/OrderDraftDetails/index.tsx
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
// @ts-strict-ignore
import { FetchResult } from "@apollo/client";
import { WindowTitle } from "@dashboard/components/WindowTitle";
import { DEFAULT_INITIAL_SEARCH_DATA } from "@dashboard/config";
import {
Expand Down Expand Up @@ -178,11 +179,8 @@ export const OrderDraftDetails: React.FC<OrderDraftDetailsProps> = ({

const handleCustomerChangeAddresses = async (
data: Partial<OrderCustomerAddressesEditDialogOutput>,
): Promise<any> =>
orderDraftUpdate.mutate({
id,
input: data,
});
): Promise<FetchResult<OrderDraftUpdateMutation>> =>
orderDraftUpdate.mutate({ id, input: data });

const handleOrderDraftCancel = async () => {
const errors = await extractMutationErrors(orderDraftCancel.mutate({ id }));
Expand Down
3 changes: 2 additions & 1 deletion src/orders/views/OrderDetails/OrderNormalDetails/index.tsx
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
// @ts-strict-ignore
import { FetchResult } from "@apollo/client";
import { WindowTitle } from "@dashboard/components/WindowTitle";
import {
CreateManualTransactionCaptureMutation,
Expand Down Expand Up @@ -149,7 +150,7 @@ export const OrderNormalDetails: React.FC<OrderNormalDetailsProps> = ({
});
const handleCustomerChangeAddresses = async (
data: Partial<OrderCustomerAddressesEditDialogOutput>,
): Promise<any> =>
): Promise<FetchResult<OrderUpdateMutation>> =>
orderUpdate.mutate({
id,
input: data,
Expand Down
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
// @ts-strict-ignore
import { FetchResult } from "@apollo/client";
import { WindowTitle } from "@dashboard/components/WindowTitle";
import { DEFAULT_INITIAL_SEARCH_DATA } from "@dashboard/config";
import {
Expand Down Expand Up @@ -156,7 +157,7 @@ export const OrderUnconfirmedDetails: React.FC<

const handleCustomerChangeAddresses = async (
data: Partial<OrderCustomerAddressesEditDialogOutput>,
): Promise<any> =>
): Promise<FetchResult<OrderUpdateMutation>> =>
orderUpdate.mutate({
id,
input: data,
Expand Down
21 changes: 16 additions & 5 deletions src/products/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -31,6 +31,15 @@ import ProductUpdateComponent from "./views/ProductUpdate";
import ProductVariantComponent from "./views/ProductVariant";
import ProductVariantCreateComponent from "./views/ProductVariantCreate";

interface MatchParams {
id?: string;
}

interface matchParamsProductVariant {
variantId?: string;
productId?: string;
}

const ProductList: React.FC<RouteComponentProps<any>> = ({ location }) => {
const qs = parseQs(location.search.substr(1)) as any;
const productListingPageFiltersFlag = useFlag("product_filters");
Expand Down Expand Up @@ -80,14 +89,16 @@ const ProductCreate: React.FC<RouteComponentProps<any>> = () => {
return <ProductCreateComponent params={params} />;
};

const ProductVariant: React.FC<RouteComponentProps<any>> = ({ match }) => {
const ProductVariant: React.FC<
RouteComponentProps<matchParamsProductVariant>
> = ({ match }) => {
const qs = parseQs(location.search.substr(1));
const params: ProductVariantEditUrlQueryParams = qs;

return (
<ProductVariantComponent
variantId={decodeURIComponent(match.params.variantId)}
productId={decodeURIComponent(match.params.productId)}
variantId={decodeURIComponent(match.params.variantId ?? "")}
productId={decodeURIComponent(match.params.productId ?? "")}
params={params}
/>
);
Expand All @@ -109,15 +120,15 @@ const ProductImage: React.FC<RouteComponentProps<any>> = ({
);
};

const ProductVariantCreate: React.FC<RouteComponentProps<any>> = ({
const ProductVariantCreate: React.FC<RouteComponentProps<MatchParams>> = ({
match,
}) => {
const qs = parseQs(location.search.substr(1));
const params: ProductVariantAddUrlQueryParams = qs;

return (
<ProductVariantCreateComponent
productId={decodeURIComponent(match.params.id)}
productId={decodeURIComponent(match.params.id ?? "")}
params={params}
/>
);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -87,10 +87,17 @@ const ShippingZonePostalCodes: React.FC<ShippingZonePostalCodesProps> = ({
);
};

const onInclusionRadioChange = (event: React.ChangeEvent<any>) => {
const onInclusionRadioChange = (
event: React.ChangeEvent<HTMLInputElement>,
) => {
const value = event.target.value;
const postalType =
value === "EXCLUDE"
? PostalCodeRuleInclusionTypeEnum.EXCLUDE
: PostalCodeRuleInclusionTypeEnum.INCLUDE;

setInclusionType(value);
onPostalCodeInclusionChange(value);
onPostalCodeInclusionChange(postalType);
};

const getPostalCodeRangeLabel = (
Expand Down

0 comments on commit b5d5740

Please sign in to comment.