fix(deps): update dependency zod to v4 (#6)
	
		
			
	
		
	
	
		
	
		
			Some checks failed
		
		
	
	
		
			
				
	
				Lint / Lint and Typecheck (push) Has been cancelled
				
			
		
		
	
	
				
					
				
			
		
			Some checks failed
		
		
	
	Lint / Lint and Typecheck (push) Has been cancelled
				
			This PR contains the following updates: | Package | Change | Age | Confidence | |---|---|---|---| | [zod](https://zod.dev) ([source](https://github.com/colinhacks/zod)) | [`^3.24.3` -> `^4.0.0`](https://renovatebot.com/diffs/npm/zod/3.25.76/4.0.5) | [](https://docs.renovatebot.com/merge-confidence/) | [](https://docs.renovatebot.com/merge-confidence/) | --- ### Release Notes <details> <summary>colinhacks/zod (zod)</summary> ### [`v4.0.5`](https://github.com/colinhacks/zod/releases/tag/v4.0.5) [Compare Source](https://github.com/colinhacks/zod/compare/v4.0.4...v4.0.5) #### Commits: - [`f91a73e`](f91a73ec23) Support pipes in discriminated unions. Closes [#​4856](https://github.com/colinhacks/zod/issues/4856) ([#​4861](https://github.com/colinhacks/zod/issues/4861)) - [`45afab0`](45afab0f84) 4.0.5 ### [`v4.0.4`](https://github.com/colinhacks/zod/releases/tag/v4.0.4) [Compare Source](https://github.com/colinhacks/zod/compare/v4.0.3...v4.0.4) #### Commits: - [`9335f05`](9335f0543d) Adds `ZodFirstPartyTypeKind` stub to fix module resolution failure inside `zod-to-json-schema` ### [`v4.0.3`](https://github.com/colinhacks/zod/releases/tag/v4.0.3) [Compare Source](44a936cb77...v4.0.3) #### Commits: - [`5905a8d`](5905a8d810) Improve check-versions script - [`f3e749b`](f3e749b1b0) Remove global File interface - [`44a936c`](44a936cb77) 4.0.2 - [`74006ed`](74006edd49) Fix JSR provenance - [`ff4af5e`](ff4af5e889) 4.0.3 - [`ce573e8`](ce573e8799) Update test badge - [`9a7161a`](9a7161a976) Fix versions ### [`v4.0.2`](https://github.com/colinhacks/zod/compare/v4.0.1...44a936cb77961e57a0988d8a3c63d9c71fce69ac) [Compare Source](https://github.com/colinhacks/zod/compare/v4.0.1...44a936cb77961e57a0988d8a3c63d9c71fce69ac) ### [`v4.0.1`](https://github.com/colinhacks/zod/releases/tag/v4.0.1): v4.0.0 [Compare Source](79d4d80e3b...v4.0.1) With this release, `zod@4.0.0` has been published to `npm`. There were no code changes between 3.25.76 and 4.0.0! Zod 4 has been stable for the past 6 weeks, but it was published inside zod@3.25.x on npm. this transitionary window gave the ecosystem time to incrementally support for Zod 4 (without dropping support for Zod 3). As there is now near-universal support for Zod 4 in the ecosystem, ths time feels right to finally put a bow on things 🎀 To upgrade to Zod 4: ``` npm upgrade zod@^4.0.0 ``` If you’ve already migrated to Zod 4 using the subpaths, there are no changes required. however you can optionally simplify your imports (recommended) ```ts // after upgrading to zod@4.0.0: import * as z from "zod"; // Zod 4 (regular) import * as z from "zod/mini" // Zod 4 Mini // these still work, but are no longer needed import * as z from "zod/v4"; import * as z from "zod/v4-mini": // if you still need Zod 3 import * as z from "zod/v3"; // Zod 3 ``` **Library authors** — if you've already implemented Zod 4 support according to the best practices outlined in the [Library authors](/library-authors) guide, bump your peer dependency to include `zod@^4.0.0`: ```json // package.json { "peerDependencies": { "zod": "^3.25.0 || ^4.0.0" } } ``` *There should be no other code changes necessary.* No code changes were made between the latest `3.25.x` release and `4.0.0`. This does not require a major version bump. ### [`v4.0.0`](https://github.com/colinhacks/zod/compare/v3.25.76...79d4d80e3b47f04752c5c281077b53f889551441) [Compare Source](https://github.com/colinhacks/zod/compare/v3.25.76...79d4d80e3b47f04752c5c281077b53f889551441) </details> --- ### Configuration 📅 **Schedule**: Branch creation - "every weekend" (UTC), Automerge - At any time (no schedule defined). 🚦 **Automerge**: Disabled by config. Please merge this manually once you are satisfied. ♻ **Rebasing**: Whenever PR becomes conflicted, or you tick the rebase/retry checkbox. 🔕 **Ignore**: Close this PR and you won't be reminded about this update again. --- - [ ] <!-- rebase-check -->If you want to rebase/retry this PR, check this box --- This PR has been generated by [Renovate Bot](https://github.com/renovatebot/renovate). <!--renovate-debug:eyJjcmVhdGVkSW5WZXIiOiI0MC40Ni4wIiwidXBkYXRlZEluVmVyIjoiNDEuMzEuMSIsInRhcmdldEJyYW5jaCI6Im1haW4iLCJsYWJlbHMiOltdfQ==--> Co-authored-by: Felix Schulze <admin@schulze.network> Reviewed-on: #6 Co-authored-by: Renovate Bot <renovatebot@schulze.network> Co-committed-by: Renovate Bot <renovatebot@schulze.network>
This commit was merged in pull request #6.
	This commit is contained in:
		
							
								
								
									
										8
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										8
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							@@ -25,7 +25,7 @@
 | 
			
		||||
        "react-hook-form": "^7.56.1",
 | 
			
		||||
        "recharts": "^2.15.3",
 | 
			
		||||
        "tailwind-merge": "^3.2.0",
 | 
			
		||||
        "zod": "^3.24.3"
 | 
			
		||||
        "zod": "^4.0.0"
 | 
			
		||||
      },
 | 
			
		||||
      "devDependencies": {
 | 
			
		||||
        "@eslint/eslintrc": "3.3.1",
 | 
			
		||||
@@ -7637,9 +7637,9 @@
 | 
			
		||||
      }
 | 
			
		||||
    },
 | 
			
		||||
    "node_modules/zod": {
 | 
			
		||||
      "version": "3.25.76",
 | 
			
		||||
      "resolved": "https://registry.npmjs.org/zod/-/zod-3.25.76.tgz",
 | 
			
		||||
      "integrity": "sha512-gzUt/qt81nXsFGKIFcC3YnfEAx5NkunCfnDlvuBSSFS02bcXu4Lmea0AFIUwbLWxWPx3d9p8S5QoaujKcNQxcQ==",
 | 
			
		||||
      "version": "4.0.5",
 | 
			
		||||
      "resolved": "https://registry.npmjs.org/zod/-/zod-4.0.5.tgz",
 | 
			
		||||
      "integrity": "sha512-/5UuuRPStvHXu7RS+gmvRf4NXrNxpSllGwDnCBcJZtQsKrviYXm54yDGV2KYNLT5kq0lHGcl7lqWJLgSaG+tgA==",
 | 
			
		||||
      "license": "MIT",
 | 
			
		||||
      "funding": {
 | 
			
		||||
        "url": "https://github.com/sponsors/colinhacks"
 | 
			
		||||
 
 | 
			
		||||
@@ -31,7 +31,7 @@
 | 
			
		||||
    "react-hook-form": "^7.56.1",
 | 
			
		||||
    "recharts": "^2.15.3",
 | 
			
		||||
    "tailwind-merge": "^3.2.0",
 | 
			
		||||
    "zod": "^3.24.3"
 | 
			
		||||
    "zod": "^4.0.0"
 | 
			
		||||
  },
 | 
			
		||||
  "devDependencies": {
 | 
			
		||||
    "@eslint/eslintrc": "3.3.1",
 | 
			
		||||
 
 | 
			
		||||
@@ -120,7 +120,7 @@ export default function FireCalculatorForm() {
 | 
			
		||||
  const [showing4percent, setShowing4percent] = useState(false);
 | 
			
		||||
 | 
			
		||||
  // Initialize form with default values
 | 
			
		||||
  const form = useForm<FormValues>({
 | 
			
		||||
  const form = useForm<z.input<typeof formSchema>, undefined, FormValues>({
 | 
			
		||||
    resolver: zodResolver(formSchema),
 | 
			
		||||
    defaultValues: {
 | 
			
		||||
      startingCapital: 50000,
 | 
			
		||||
@@ -258,11 +258,18 @@ export default function FireCalculatorForm() {
 | 
			
		||||
                        <Input
 | 
			
		||||
                          placeholder="e.g., 10000"
 | 
			
		||||
                          type="number"
 | 
			
		||||
                          {...field}
 | 
			
		||||
                          onChange={(value) => {
 | 
			
		||||
                            field.onChange(value);
 | 
			
		||||
                          value={field.value as number | string | undefined}
 | 
			
		||||
                          onChange={(e) => {
 | 
			
		||||
                            field.onChange(
 | 
			
		||||
                              e.target.value === ""
 | 
			
		||||
                                ? undefined
 | 
			
		||||
                                : Number(e.target.value),
 | 
			
		||||
                            );
 | 
			
		||||
                            void form.handleSubmit(onSubmit)();
 | 
			
		||||
                          }}
 | 
			
		||||
                          onBlur={field.onBlur}
 | 
			
		||||
                          name={field.name}
 | 
			
		||||
                          ref={field.ref}
 | 
			
		||||
                        />
 | 
			
		||||
                      </FormControl>
 | 
			
		||||
                      <FormMessage />
 | 
			
		||||
@@ -279,11 +286,18 @@ export default function FireCalculatorForm() {
 | 
			
		||||
                        <Input
 | 
			
		||||
                          placeholder="e.g., 500"
 | 
			
		||||
                          type="number"
 | 
			
		||||
                          {...field}
 | 
			
		||||
                          onChange={(value) => {
 | 
			
		||||
                            field.onChange(value);
 | 
			
		||||
                          value={field.value as number | string | undefined}
 | 
			
		||||
                          onChange={(e) => {
 | 
			
		||||
                            field.onChange(
 | 
			
		||||
                              e.target.value === ""
 | 
			
		||||
                                ? undefined
 | 
			
		||||
                                : Number(e.target.value),
 | 
			
		||||
                            );
 | 
			
		||||
                            void form.handleSubmit(onSubmit)();
 | 
			
		||||
                          }}
 | 
			
		||||
                          onBlur={field.onBlur}
 | 
			
		||||
                          name={field.name}
 | 
			
		||||
                          ref={field.ref}
 | 
			
		||||
                        />
 | 
			
		||||
                      </FormControl>
 | 
			
		||||
                      <FormMessage />
 | 
			
		||||
@@ -300,11 +314,18 @@ export default function FireCalculatorForm() {
 | 
			
		||||
                        <Input
 | 
			
		||||
                          placeholder="e.g., 30"
 | 
			
		||||
                          type="number"
 | 
			
		||||
                          {...field}
 | 
			
		||||
                          onChange={(value) => {
 | 
			
		||||
                            field.onChange(value);
 | 
			
		||||
                          value={field.value as number | string | undefined}
 | 
			
		||||
                          onChange={(e) => {
 | 
			
		||||
                            field.onChange(
 | 
			
		||||
                              e.target.value === ""
 | 
			
		||||
                                ? undefined
 | 
			
		||||
                                : Number(e.target.value),
 | 
			
		||||
                            );
 | 
			
		||||
                            void form.handleSubmit(onSubmit)();
 | 
			
		||||
                          }}
 | 
			
		||||
                          onBlur={field.onBlur}
 | 
			
		||||
                          name={field.name}
 | 
			
		||||
                          ref={field.ref}
 | 
			
		||||
                        />
 | 
			
		||||
                      </FormControl>
 | 
			
		||||
                      <FormMessage />
 | 
			
		||||
@@ -321,11 +342,18 @@ export default function FireCalculatorForm() {
 | 
			
		||||
                        <Input
 | 
			
		||||
                          placeholder="e.g., 90"
 | 
			
		||||
                          type="number"
 | 
			
		||||
                          {...field}
 | 
			
		||||
                          onChange={(value) => {
 | 
			
		||||
                            field.onChange(value);
 | 
			
		||||
                          value={field.value as number | string | undefined}
 | 
			
		||||
                          onChange={(e) => {
 | 
			
		||||
                            field.onChange(
 | 
			
		||||
                              e.target.value === ""
 | 
			
		||||
                                ? undefined
 | 
			
		||||
                                : Number(e.target.value),
 | 
			
		||||
                            );
 | 
			
		||||
                            void form.handleSubmit(onSubmit)();
 | 
			
		||||
                          }}
 | 
			
		||||
                          onBlur={field.onBlur}
 | 
			
		||||
                          name={field.name}
 | 
			
		||||
                          ref={field.ref}
 | 
			
		||||
                        />
 | 
			
		||||
                      </FormControl>
 | 
			
		||||
                      <FormMessage />
 | 
			
		||||
@@ -343,11 +371,18 @@ export default function FireCalculatorForm() {
 | 
			
		||||
                          placeholder="e.g., 7"
 | 
			
		||||
                          type="number"
 | 
			
		||||
                          step="0.1"
 | 
			
		||||
                          {...field}
 | 
			
		||||
                          onChange={(value) => {
 | 
			
		||||
                            field.onChange(value);
 | 
			
		||||
                          value={field.value as number | string | undefined}
 | 
			
		||||
                          onChange={(e) => {
 | 
			
		||||
                            field.onChange(
 | 
			
		||||
                              e.target.value === ""
 | 
			
		||||
                                ? undefined
 | 
			
		||||
                                : Number(e.target.value),
 | 
			
		||||
                            );
 | 
			
		||||
                            void form.handleSubmit(onSubmit)();
 | 
			
		||||
                          }}
 | 
			
		||||
                          onBlur={field.onBlur}
 | 
			
		||||
                          name={field.name}
 | 
			
		||||
                          ref={field.ref}
 | 
			
		||||
                        />
 | 
			
		||||
                      </FormControl>
 | 
			
		||||
                      <FormMessage />
 | 
			
		||||
@@ -365,11 +400,18 @@ export default function FireCalculatorForm() {
 | 
			
		||||
                          placeholder="e.g., 2"
 | 
			
		||||
                          type="number"
 | 
			
		||||
                          step="0.1"
 | 
			
		||||
                          {...field}
 | 
			
		||||
                          onChange={(value) => {
 | 
			
		||||
                            field.onChange(value);
 | 
			
		||||
                          value={field.value as number | string | undefined}
 | 
			
		||||
                          onChange={(e) => {
 | 
			
		||||
                            field.onChange(
 | 
			
		||||
                              e.target.value === ""
 | 
			
		||||
                                ? undefined
 | 
			
		||||
                                : Number(e.target.value),
 | 
			
		||||
                            );
 | 
			
		||||
                            void form.handleSubmit(onSubmit)();
 | 
			
		||||
                          }}
 | 
			
		||||
                          onBlur={field.onBlur}
 | 
			
		||||
                          name={field.name}
 | 
			
		||||
                          ref={field.ref}
 | 
			
		||||
                        />
 | 
			
		||||
                      </FormControl>
 | 
			
		||||
                      <FormMessage />
 | 
			
		||||
@@ -388,11 +430,18 @@ export default function FireCalculatorForm() {
 | 
			
		||||
                        <Input
 | 
			
		||||
                          placeholder="e.g., 2000"
 | 
			
		||||
                          type="number"
 | 
			
		||||
                          {...field}
 | 
			
		||||
                          onChange={(value) => {
 | 
			
		||||
                            field.onChange(value);
 | 
			
		||||
                          value={field.value as number | string | undefined}
 | 
			
		||||
                          onChange={(e) => {
 | 
			
		||||
                            field.onChange(
 | 
			
		||||
                              e.target.value === ""
 | 
			
		||||
                                ? undefined
 | 
			
		||||
                                : Number(e.target.value),
 | 
			
		||||
                            );
 | 
			
		||||
                            void form.handleSubmit(onSubmit)();
 | 
			
		||||
                          }}
 | 
			
		||||
                          onBlur={field.onBlur}
 | 
			
		||||
                          name={field.name}
 | 
			
		||||
                          ref={field.ref}
 | 
			
		||||
                        />
 | 
			
		||||
                      </FormControl>
 | 
			
		||||
                      <FormMessage />
 | 
			
		||||
@@ -406,11 +455,13 @@ export default function FireCalculatorForm() {
 | 
			
		||||
                  name="retirementAge"
 | 
			
		||||
                  render={({ field }) => (
 | 
			
		||||
                    <FormItem>
 | 
			
		||||
                      <FormLabel>Retirement Age: {field.value}</FormLabel>
 | 
			
		||||
                      <FormLabel>
 | 
			
		||||
                        Retirement Age: {field.value as number}
 | 
			
		||||
                      </FormLabel>
 | 
			
		||||
                      <FormControl>
 | 
			
		||||
                        <Slider
 | 
			
		||||
                          name="retirementAge"
 | 
			
		||||
                          value={[field.value]}
 | 
			
		||||
                          value={[field.value as number]}
 | 
			
		||||
                          min={25}
 | 
			
		||||
                          max={75}
 | 
			
		||||
                          step={1}
 | 
			
		||||
@@ -563,8 +614,8 @@ export default function FireCalculatorForm() {
 | 
			
		||||
                        <ReferenceLine
 | 
			
		||||
                          x={
 | 
			
		||||
                            irlYear +
 | 
			
		||||
                            (form.getValues("retirementAge") -
 | 
			
		||||
                              form.getValues("currentAge"))
 | 
			
		||||
                            (Number(form.getValues("retirementAge")) -
 | 
			
		||||
                              Number(form.getValues("currentAge")))
 | 
			
		||||
                          }
 | 
			
		||||
                          stroke="var(--primary)"
 | 
			
		||||
                          strokeWidth={2}
 | 
			
		||||
@@ -579,7 +630,7 @@ export default function FireCalculatorForm() {
 | 
			
		||||
                            x={
 | 
			
		||||
                              irlYear +
 | 
			
		||||
                              (result.retirementAge4percent -
 | 
			
		||||
                                form.getValues("currentAge"))
 | 
			
		||||
                                Number(form.getValues("currentAge")))
 | 
			
		||||
                            }
 | 
			
		||||
                            stroke="var(--secondary)"
 | 
			
		||||
                            strokeWidth={1}
 | 
			
		||||
@@ -642,8 +693,8 @@ export default function FireCalculatorForm() {
 | 
			
		||||
                </CardHeader>
 | 
			
		||||
                <CardContent>
 | 
			
		||||
                  <p className="text-3xl font-bold">
 | 
			
		||||
                    {form.getValues("lifeExpectancy") -
 | 
			
		||||
                      form.getValues("retirementAge")}
 | 
			
		||||
                    {Number(form.getValues("lifeExpectancy")) -
 | 
			
		||||
                      Number(form.getValues("retirementAge"))}
 | 
			
		||||
                  </p>
 | 
			
		||||
                </CardContent>
 | 
			
		||||
              </Card>
 | 
			
		||||
@@ -674,7 +725,7 @@ export default function FireCalculatorForm() {
 | 
			
		||||
                    </CardHeader>
 | 
			
		||||
                    <CardContent>
 | 
			
		||||
                      <p className="text-3xl font-bold">
 | 
			
		||||
                        {form.getValues("lifeExpectancy") -
 | 
			
		||||
                        {Number(form.getValues("lifeExpectancy")) -
 | 
			
		||||
                          (result.retirementAge4percent ?? 0)}
 | 
			
		||||
                      </p>
 | 
			
		||||
                    </CardContent>
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user