|
"source": "/// <reference types=\"@raycast/api\">\n\n/* \ud83d\udea7 \ud83d\udea7 \ud83d\udea7\n * This file is auto-generated from the extension's manifest.\n * Do not modify manually. Instead, update the `package.json` file.\n * \ud83d\udea7 \ud83d\udea7 \ud83d\udea7 */\n\n/* eslint-disable @typescript-eslint/ban-types */\n\ntype ExtensionPreferences = {\n /** Image Input - Where to obtain the image to modify. */\n \"inputMethod\": \"Finder\" | \"Path Finder\" | \"Clipboard\",\n /** Image Output - How to handle the result of the image modification, i.e. where to save the modified image, or whether to copy it to the clipboard. */\n \"imageResultHandling\": \"replaceOriginal\" | \"saveInContainingFolder\" | \"copyToClipboard\" | \"openInPreview\" | \"saveToDownloads\" | \"saveToDesktop\",\n /** cwebp Lossless - Whether to use lossless conversion */\n \"cwebpLossless\": boolean\n}\n\n/** Preferences accessible in all the extension's commands */\ndeclare type Preferences = ExtensionPreferences\n\ndeclare namespace Preferences {\n /** Preferences accessible in the `commander` command */\n export type Commander = ExtensionPreferences & {\n /** Name of Command to run - The name of the command/function to run */\n \"name\"?: string\n}\n /** Preferences accessible in the `commanderOpenNewFinderWindow` command */\n export type CommanderOpenNewFinderWindow = ExtensionPreferences & {\n /** Name of Command to run - The name of the command/function to run */\n \"name\"?: string\n}\n /** Preferences accessible in the `commanderTrim` command */\n export type CommanderTrim = ExtensionPreferences & {\n /** Name of Command to run - The name of the command/function to run */\n \"name\"?: string\n}\n /** Preferences accessible in the `commanderMp4ToMp3` command */\n export type CommanderMp4ToMp3 = ExtensionPreferences & {\n /** Name of Command to run - The name of the command/function to run */\n \"name\"?: string\n}\n /** Preferences accessible in the `commanderConvert` command */\n export type CommanderConvert = ExtensionPreferences & {\n /** Name of Command to run - The name of the command/function to run */\n \"name\"?: string,\n /** Additional - Whether to trim the image */\n \"trim\": boolean,\n /** Enabled Formats - Whether to show WEBP as a conversion option */\n \"showWEBP\": boolean,\n /** - Whether to show ASTC as a conversion option */\n \"showASTC\": boolean,\n /** - Whether to show BMP as a conversion option */\n \"showBMP\": boolean,\n /** - Whether to show DDS as a conversion option */\n \"showDDS\": boolean,\n /** - Whether to show EXR as a conversion option */\n \"showEXR\": boolean,\n /** - Whether to show GIF as a conversion option */\n \"showGIF\": boolean,\n /** - Whether to show HEIC as a conversion option */\n \"showHEIC\": boolean,\n /** - Whether to show HEICS as a conversion option */\n \"showHEICS\": boolean,\n /** - Whether to show ICNS as a conversion option */\n \"showICNS\": boolean,\n /** - Whether to show ICO as a conversion option */\n \"showICO\": boolean,\n /** - Whether to show JPEG as a conversion option */\n \"showJPEG\": boolean,\n /** - Whether to show JP2 as a conversion option */\n \"showJP2\": boolean,\n /** - Whether to show KTX as a conversion option */\n \"showKTX\": boolean,\n /** - Whether to show PBM as a conversion option */\n \"showPBM\": boolean,\n /** - Whether to show PDF as a conversion option */\n \"showPDF\": boolean,\n /** - Whether to show PNG as a conversion option */\n \"showPNG\": boolean,\n /** - Whether to show PSD as a conversion option */\n \"showPSD\": boolean,\n /** - Whether to show PVR as a conversion option */\n \"showPVR\": boolean,\n /** - Whether to show TGA as a conversion option */\n \"showTGA\": boolean,\n /** - Whether to show TIFF as a conversion option */\n \"showTIFF\": boolean,\n /** - Whether to show SVG as a conversion option */\n \"showSVG\": boolean\n}\n}\n\ndeclare namespace Arguments {\n /** Arguments passed to the `commander` command */\n export type Commander = {}\n /** Arguments passed to the `commanderOpenNewFinderWindow` command */\n export type CommanderOpenNewFinderWindow = {\n /** Path */\n \"path\": string\n}\n /** Arguments passed to the `commanderTrim` command */\n export type CommanderTrim = {}\n /** Arguments passed to the `commanderMp4ToMp3` command */\n export type CommanderMp4ToMp3 = {}\n /** Arguments passed to the `commanderConvert` command */\n export type CommanderConvert = {}\n}\n\n",
|
|
"review": "8\n\n## Bugs\n- No explicit errors or issues were identified from the provided code as it primarily concerns type definitions and does not contain implementation logic.\n\n## Optimizations\n- Type aliasing can be used for the repetitive format options to reduce redundancy.\n- Consider breaking down the `Preferences` type into smaller, more manageable pieces if the structure is expected to grow more complex.\n\n## Good points\n- The use of TypeScript's `type` and `namespace` for organizing and defining data structure brings clarity and structure to the code.\n- Provides clear indication of where to update the code (`package.json` file) rather than the generated code itself.\n- Extensive use of comments to explain each property, which enhances understandability and maintainability.\n\n## Summary\nThe provided code is a clean implementation of type declarations using TypeScript, suitable for an auto-generated file that should not be modified manually. It demonstrates good practices in terms of clarity, organization, and documentation of code. However, there might be room for optimization through the use of type aliasing for repetitive code sections.\n\n## Open source alternatives\n- [ImageMagick](https://imagemagick.org) - an open-source software suite for displaying, converting, and editing raster image and vector image files.\n- [GraphicsMagick](http://www.graphicsmagick.org/) - known as the Swiss Army knife of image processing, it is a robust collection of tools and libraries to read, write, and manipulate an image in any of the more popular image formats.",
|