@amj7/lucide-patch-nativescript-vue v1.0.12
@amj7/lucide-patch-nativescript-vue
Patches lucide-vue-next
to be used in NativeScript Vue 3 via @nativescript-community/ui-svg
and @vue/server-renderer
.
This package addresses compatibility issues between lucide-vue-next
and NativeScript Vue 3 by:
- Applying a patch (
lucide-vue-next+0.475.0.patch
) to your project during thepostinstall
script. - Providing a
nativescript.webpack.js
in the plugin that overrides imports of "vue" within@vue/server-renderer
to point back to original vue. - Enabling tree-shaking for
lucide-vue-next
icons in your NativeScript Vue 3 application.
Installation
Install Peer Dependencies:
npm install @nativescript-community/ui-canvas @nativescript-community/ui-svg @vue/server-renderer
Install this Package:
npm install @amj7/lucide-patch-nativescript-vue
The
postinstall
script will automatically apply the patch to yourlucide-vue-next
dependency (version^0.475.0
).Register SVGView:
In your
app.js
(or equivalent entry point):import { registerElement } from "nativescript-vue"; registerElement( "SVGView", () => require("@nativescript-community/ui-svg").SVGView );
Usage
Refer to the Lucide Vue Next documentation for general usage instructions. This package ensures compatibility with NativeScript Vue 3.
<script setup>
import { Camera } from "lucide-vue-next";
</script>
<template>
<Camera color="red" :size="32" />
</template>
// Inherited css color supported! (v1.0.7) // Examples:
<template>
<Camera class="text-black dark:text-white" />
</template>
<template>
<Page class="text-foreground">
...
<Camera />
</Page>
</template>
Props
Prop | Type | Default |
---|---|---|
size | number | 24 |
color | string | currentColor |
stroke-width | number | 2 |
absolute-stroke-width | boolean | false |
default-class | string | lucide-icon |
Troubleshooting
Verifying the Patch: Check if
node_modules/lucide-vue-next/dist/esm/createLucideIcon.js
has been modified. You should see adefineComponent
call within the file. If the patch hasn't been applied, try runningnpm install
again.TypeError: Vue.initDirectivesForSSR is not a function
: This error indicates that thenativescript.webpack.js
plugin was not applied correctly.Manual Configuration: Add the webpack rule directly to your
webpack.config.js
file.// webpack.config.js const webpack = require("@nativescript/webpack"); const path = require("path"); module.exports = (env) => { webpack.init(env); webpack.chainWebpack((config) => { // Create a new rule for files coming from the specific package. config.module .rule("override-vue-for-server-renderer") .test(/\.(js|vue)$/) .include.add( path.resolve(__dirname, "node_modules", "@vue", "server-renderer") ) .end() // Override the resolution so that any import of "vue" in @vue/server-renderer files points to the original Vue package .resolve.alias.set( "vue", path.resolve(__dirname, "node_modules/vue") ); }); return webpack.resolveConfig(); };
UnhandledSchemeError: Reading from "node:stream" is not handled
:If you're trying to use
stream-browserify
in your project, you might need to patch@vue/server-renderer/dist/server-renderer.cjs.js
usingnpx patch-package
orbun patch
:- const stream = new (require("node:stream")).Readable({ read() { + const stream = new (require("stream-browserify")).Readable({ read() {
If using Bun, there's a known bug that breaks bun patch with @scoped packages. So you'll need to use quotes around the package name and fix the file .patch filename manually to @vue+server-renderer@3.5.13.patch once done.