
* refactor: ♻️ replace material-ui with macaw-ui; remove all views * add apps-ui * feat: add configuration screen (#514) * feat: ✨ add basic layout * refactor: 🔥 enabled field * refactor: ♻️ move part of config to credentials * refactor: ♻️ move address from channel to provider * feat: ✨ add all states for providers * refactor: ♻️ merge redesign with refactor * refactor: ♻️ replace material-ui with macaw-ui; remove all views * fix: 🐛 text-decoration on breadcrumb link * feat: ✨ add stripe icon * feat: ✨ add AppCard * feat: ✨ add AppBreadcrumbs and new provider pages * refactor: ♻️ add gridRatio to support two app grids * refactor: 🔥 theme-synchronizer test * refactor: ♻️ make breadcrumbs bulletproof * fix: 🐛 failing build * feat: ✨ add app-layout * build: ⬆️ upgrade macaw-ui * feat: redesign provider forms (#533) * build: ➕ add @saleor/react-hook-form-macaw * feat: add binding for Toggle in react-hook-form-macaw * feat: ✨ add AppToggle component * feat: ✨ add create-avatax-configuration and edit-avatax-configuration * feat: ✨ add taxjar-validation-service with address validation * feat: ✨ add AvataxValidationService * feat: ✨ add edit/create taxjar config * feat: ✨ add delete configuration * refactor: ♻️ change invalid address error message * refactor: ♻️ throw in validation services instead of authenticated: true/false * docs: 💡 add todo comments * refactor: ♻️ better variable naming in parse error * fix: 🐛 disable button when loading * refactor: ♻️ make defaultValues required * refactor: 🔥 remove custom fontWeights * fix: 🐛 toggle form submission bug * feat: ✨ extract provider-label and use in forms * feat: ✨ use new Section component and change copy * refactor: ♻️ use ProviderLabel in ProvidersTable * build: 💚 fix lockfile * fix: 🐛 address feedback * feat: channel provider table (#538) * refactor: 🔥 providers-config-input-schema * refactor: ♻️ move providers * feat: ✨ add basic channel-list * refactor: 🚚 move around * feat: ✨ add ChannelConfigurationService * feat: ✨ add select provider in channel table * refactor: 🔥 logger traces * refactor: 🔊 refine logs * feat: ✅ add avatax-config-mock-generator and use in webhooks mock generators * refactor: ♻️ split up avatax-validation.service and add tests for response resolver * feat: ✅ add avatax-validation-error-resolver tests * refactor: 🚚 move taxjar-validation.service to separate folder * feat: ✅ extract taxjar-validation-error-resolver and add tests * feat: ✅ add channel-config-mock-generator * feat: ✅ add ChannelFetcherMockGenerator * test: ✅ add tests for channel-configuration-merge * test: ✅ add tests for crud-settings.service * fix: 💬 channel copy * refactor: 🔊 remove data from logs * refactor: 🚚 move configuration & validation to configuration folder * fix: 🐛 imports * fix: 🐛 showing loading & add at the same time * refactor: ♻️ public configurations & obfuscation rework * refactor: 🚚 extract repositories from services * refactor: 🚚 instance -> connection (#544) * refactor: ♻️ move creating configuration service to procedure * fix: 🐛 some paths & names while renaming * Update apps/taxes/src/pages/api/webhooks/order-calculate-taxes.ts * Update apps/taxes/src/pages/api/webhooks/checkout-calculate-taxes.ts * feat: shipping tax code (#555) * fix: 💄 minor visual issues * feat: ✨ add shipping tax code * fix: 🐛 fix toggle * refactor: ♻️ use common table in providers-table * docs: 💡 add comment to obfuscator * feat: ✨ sort countries by label not code * Taxes 💸: Add runtime migrations to schema v2 (#545) * build: ➕ add dotenv * feat: 🚧 add draft of migration scripts * refactor: ♻️ settingsManager to accept appId * feat: ✨ tax-providers and channels transforms * feat: ✨ add migration classes * feat: 🚧 add migration to connection getAll * feat: 🚧 add dummy data script * feat: ✨ add runtime channel migration * feat: ✨ add migration and report scripts * fix: 🐛 name of dummy class method * feat: ✅ add transform tests * build: 💚 update lockfile * fix: creating & updating a provider (#563) * refactor: ✅ improve the test for update * docs: 💡 comment crud-settings * refactor: 🔥 unused file * fix: 🐛 appId bug * refactor: 🚚 rename dummy-utils * fix: 💄 padding in table * refactor: 💬 change avatax texts * build: 👷 add changeset
100 lines
2.8 KiB
TypeScript
100 lines
2.8 KiB
TypeScript
import { z } from "zod";
|
|
import { createLogger } from "../../lib/logger";
|
|
import { protectedClientProcedure } from "../trpc/protected-client-procedure";
|
|
import { router } from "../trpc/trpc-server";
|
|
import { avataxConfigSchema } from "./avatax-connection-schema";
|
|
import { PublicAvataxConnectionService } from "./configuration/public-avatax-connection.service";
|
|
|
|
const getInputSchema = z.object({
|
|
id: z.string(),
|
|
});
|
|
|
|
const deleteInputSchema = z.object({
|
|
id: z.string(),
|
|
});
|
|
|
|
const patchInputSchema = z.object({
|
|
id: z.string(),
|
|
value: avataxConfigSchema.deepPartial(),
|
|
});
|
|
|
|
const postInputSchema = z.object({
|
|
value: avataxConfigSchema,
|
|
});
|
|
|
|
const protectedWithConfigurationService = protectedClientProcedure.use(({ next, ctx }) =>
|
|
next({
|
|
ctx: {
|
|
...ctx,
|
|
connectionService: new PublicAvataxConnectionService(
|
|
ctx.apiClient,
|
|
ctx.appId!,
|
|
ctx.saleorApiUrl
|
|
),
|
|
},
|
|
})
|
|
);
|
|
|
|
export const avataxConnectionRouter = router({
|
|
getById: protectedWithConfigurationService.input(getInputSchema).query(async ({ ctx, input }) => {
|
|
const logger = createLogger({
|
|
location: "avataxConnectionRouter.get",
|
|
});
|
|
|
|
logger.debug("Route get called");
|
|
|
|
const result = await ctx.connectionService.getById(input.id);
|
|
|
|
logger.info(`Avatax configuration with an id: ${result.id} was successfully retrieved`);
|
|
|
|
return result;
|
|
}),
|
|
create: protectedWithConfigurationService
|
|
.input(postInputSchema)
|
|
.mutation(async ({ ctx, input }) => {
|
|
const logger = createLogger({
|
|
saleorApiUrl: ctx.saleorApiUrl,
|
|
procedure: "avataxConnectionRouter.post",
|
|
});
|
|
|
|
logger.debug("Attempting to create configuration");
|
|
|
|
const result = await ctx.connectionService.create(input.value);
|
|
|
|
logger.info("Avatax configuration was successfully created");
|
|
|
|
return result;
|
|
}),
|
|
delete: protectedWithConfigurationService
|
|
.input(deleteInputSchema)
|
|
.mutation(async ({ ctx, input }) => {
|
|
const logger = createLogger({
|
|
saleorApiUrl: ctx.saleorApiUrl,
|
|
procedure: "avataxConnectionRouter.delete",
|
|
});
|
|
|
|
logger.debug("Route delete called");
|
|
|
|
const result = await ctx.connectionService.delete(input.id);
|
|
|
|
logger.info(`Avatax configuration with an id: ${input.id} was deleted`);
|
|
|
|
return result;
|
|
}),
|
|
update: protectedWithConfigurationService
|
|
.input(patchInputSchema)
|
|
.mutation(async ({ ctx, input }) => {
|
|
const logger = createLogger({
|
|
saleorApiUrl: ctx.saleorApiUrl,
|
|
procedure: "avataxConnectionRouter.patch",
|
|
});
|
|
|
|
logger.debug("Route patch called");
|
|
|
|
const result = await ctx.connectionService.update(input.id, input.value);
|
|
|
|
logger.info(`Avatax configuration with an id: ${input.id} was successfully updated`);
|
|
|
|
return result;
|
|
}),
|
|
});
|