macana

Static site generator for Obsidian Vault

  1. 1
  2. 2
  3. 3
  4. 4
  5. 5
  6. 6
  7. 7
  8. 8
  9. 9
  10. 10
  11. 11
  12. 12
  13. 13
  14. 14
  15. 15
  16. 16
  17. 17
  18. 18
  19. 19
  20. 20
  21. 21
  22. 22
  23. 23
  24. 24
  25. 25
  26. 26
  27. 27
  28. 28
  29. 29
  30. 30
  31. 31
  32. 32
  33. 33
  34. 34
  35. 35
  36. 36
  37. 37
  38. 38
  39. 39
  40. 40
  41. 41
  42. 42
  43. 43
  44. 44
  45. 45
  46. 46
  47. 47
  48. 48
  49. 49
  50. 50
  51. 51
  52. 52
  53. 53
  54. 54
  55. 55
// SPDX-FileCopyrightText: 2024 Shota FUJI <pockawoooh@gmail.com>
//
// SPDX-License-Identifier: Apache-2.0

/** @jsx h */

import {
	createContext,
	h,
	useContext,
} from "../../../deps/deno.land/x/nano_jsx/mod.ts";

interface PathResolver {
	resolve(path: readonly string[]): string;
}

const PathResolverContext = createContext({
	resolve(path: readonly string[]) {
		return path.join("/");
	},
});

export function usePathResolver(): PathResolver {
	return useContext(PathResolverContext);
}

export interface PathResolverProviderProps {
	/**
	 * How deep the path from the root?
	 * 0 for top-level documents.
	 * For example, the depth for "foo/bar/baz.html" is 2.
	 *
	 * @default 0
	 */
	depth?: number;

	children: JSX.ElementChildrenAttribute["children"];
}

export function PathResolverProvider(
	{ depth = 0, children }: PathResolverProviderProps,
) {
	const resolver: PathResolver = {
		resolve(path) {
			return Array.from({ length: depth }, () => "../").join("") +
				path.join("/");
		},
	};

	return (
		<PathResolverContext.Provider value={resolver}>
			{children}
		</PathResolverContext.Provider>
	);
}