-
-
Notifications
You must be signed in to change notification settings - Fork 3.6k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Add Vue SFC support to AEs #17718
Comments
FWIW I switch :item with v-bind:item and then I got an error about <script setup>
|
The UI kit build process doesn't support Vue SFCs(i.e., |
Hi @yusufkandemir, do you have a timeline on when you be implementing it. |
Hi, unfortunately, no. /cc @rstoenescu |
@whoacowboy If you want I have updated my build scripts to support SFC, esm and typescript but my app extension is not open sourced yet You will also need to update some dev deps like Details
{
"name": "quasar-ui-milkdown",
"version": "0.0.1",
"author": "Jean Claveau <[email protected]>",
"description": "Milkdown smooth integration with Quasar framework",
"license": "MIT",
"type": "module",
"//module": "dist/index.esm.js",
"//main": "dist/index.common.js",
"module": "dist/esm/apps/quasar-ui-milkdown/ui/src/index.esm.js",
"main": "dist/esm/apps/quasar-ui-milkdown/ui/src/index.esm.js",
"scripts": {
"dev:clean": "cd dev && quasar clean && rm -rf node_modules/.q-cache",
"deveuh": "cd dev && pnpm dev --debug && cd ..",
"dev:umd": "pnpm build && node build/script.open-umd.js",
"dev:ssr": "cd dev && pnpm 'dev:ssr' && cd ..",
"dev:ios": "cd dev && pnpm 'dev:ios' && cd ..",
"dev:android": "cd dev && pnpm 'dev:android' && cd ..",
"dev:electron": "cd dev && pnpm 'dev:electron' && cd ..",
"build": "node build/index.js",
"build:js": "node build/script.javascript.js",
"build:css": "node build/script.css.js",
"test": "playwright test",
"test:watch": "PWTEST_WATCH=1 playwright test",
"test:ui": "playwright test --ui",
"test:headed": "playwright test --headed",
"test:update-snapshots": "playwright test --update-snapshots",
"test:gen": "playwright codegen",
"link:local-clone": "node ./scripts/link.js",
"": ""
},
"devDependencies": {
"@playwright/test": "^1.49.1",
"@prosemirror-adapter/vue": "^0.2.6",
"@quasar/app-vite": "2.0.4",
"@quasar/extras": "^1.16.4",
"@rollup/plugin-buble": "^1.0.3",
"@rollup/plugin-commonjs": "^28.0.2",
"@rollup/plugin-json": "^6.1.0",
"@rollup/plugin-node-resolve": "^16.0.0",
"@rollup/plugin-replace": "^6.0.2",
"autoprefixer": "^10.0.2",
"chalk": "^5.4.1",
"core-js": "^3.39.0",
"cssnano": "^7.0.6",
"fs-extra": "^8.1.0",
"glob": "^11.0.0",
"open": "^7.3.0",
"playwright": "^1.49.1",
"postcss": "^8.1.9",
"prosemirror-dev-toolkit": "^1.1.8",
"quasar": "^2.17.5",
"rimraf": "^6.0.1",
"rollup": "^4.29.2",
"rollup-plugin-esbuild": "^6.1.1",
"rollup-plugin-polyfill-node": "^0.13.0",
"rollup-plugin-postcss": "^4.0.2",
"rollup-plugin-styles": "^4.0.0",
"rtlcss": "^2.6.1",
"sass": "^1.33.0",
"uglify-js": "^3.13.3",
"unplugin-vue": "^5.2.1",
"vue": "^3.5.13",
"vue-router": "^4.0.0",
"webfontloader": "^1.6.28",
"zlib": "^1.0.5"
},
"browserslist": [
"last 4 Chrome versions",
"last 4 Firefox versions",
"last 2 Edge versions",
"last 4 Safari versions",
"last 4 Android versions",
"last 4 ChromeAndroid versions",
"last 4 FirefoxAndroid versions",
"last 4 iOS versions"
],
"dependencies": {
"@milkdown/kit": "^7.5.9",
"@milkdown/theme-nord": "^7.5.9",
"@milkdown/vue": "^7.5.9",
"fuse.js": "^7.0.0"
}
} Just take in consideration it's a work in progress plz @yusufkandemir If what I shared seems to be the right direction to you, I may patch the app extension template submit a PR Edit: I updated the zip and package after a little clean up |
@jclaveau This is great, thank you. I am working on integrating it now. Do you have a rollup.config.js or are you not using one? |
You're welcome. It's always a pleasure when value is created from my work 🙏
Nope, I stuck to the previous philosophy.
One thing more: if you want to use Quasar components in the SFC without imports and in kebab-case you will need something like this in your import MilkdownEditorWrappable from './components/MilkdownEditorWrappable.vue'
import MilkdownEditor from './components/MilkdownEditor.vue'
const version = __UI_VERSION__
import {
QPopupProxy,
QList,
QItem,
QItemSection,
QItemLabel,
QAvatar,
QIcon,
QTooltip,
} from 'quasar';
import * as directives from 'quasar/src/directives.js'
function install (app) {
[
QPopupProxy,
QList,
QItem,
QItemSection,
QItemLabel,
QAvatar,
QIcon,
QTooltip,
].forEach((component) => {
app.component(component.name, component)
})
Object.entries(directives).forEach(([_key, directive]) => {
app.directive(directive.name, directive)
})
app.component(MilkdownEditor.__name, MilkdownEditor)
app.component(MilkdownEditorWrappable.__name, MilkdownEditorWrappable)
}
export {
version,
MilkdownEditor,
MilkdownEditorWrappable,
install
} |
@jclaveau Thank you that is very helpful. I am having similar issues with scss inside the SFCs.
I had to change the What errors are you getting? |
What happened?
I created a new ui app-extension and only modified the Component.js. When executing
yarn build
I receive an error if I use the short hand@
instead ofv-on:
and I also get an error when I use a computed attribute inside a template:label="item"
or:data-item="item"
.and
error for slightly different reasons but it appears to be buble causing the issue.
I have tried this with div tag as well and I receive the same error.
What did you expect to happen?
I expected the app-extension ui framework to support the @ shorthand and the hyphenated dynamic attributes.
Reproduction URL
https://github.com/whoacowboy/app-extension-bug
How to reproduce?
Create a new UI App extension.
During the CLI process, enter default info wherever possible and appropriate info where user input is required.
Install dependencies
Rename
src/components/Component.js
tosrc/components/Component.vue
Replace the code in
src/Components.vue
with the follow code and saveRun the build script
Flavour
Quasar CLI with Webpack (@quasar/cli | @quasar/app-webpack)
Areas
App Extension API
Platforms/Browsers
Chrome
Quasar info output
`quasar info` Operating System Darwin(23.6.0) - darwin/arm64 NodeJs 20.11.0 Global packages NPM 10.2.4 yarn 1.22.22 pnpm Not installed bun Not installed @quasar/cli 2.4.1 @quasar/icongenie Not installed cordova Not installed Networking Host James.localdomain en1 192.168.4.4 bridge1 192.168.1.70
Relevant log output
Additional context
No response
The text was updated successfully, but these errors were encountered: