Skip to content
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

Replace httpvueloader with vue3-sfc-loader #109

Open
wants to merge 12 commits into
base: master
Choose a base branch
from

Conversation

HeriLFIU
Copy link
Collaborator

@HeriLFIU HeriLFIU commented Oct 21, 2024

Closes #85
Closes #105

Summary

Replaced httpvueloader with vue3-sfc-loader.

Mef-eline was trying to access and change the value of a prop within k-accordion-item through references, and props are read only. Because of this, the prop was switched for a data element since no component was using the prop functionality and the data element can be modified.

Mef-eline was trying to give the prop named value from k-input an integer value. This prop was typed and expected a string; because of this, the type specification was removed from the prop, and now it can accept any value.

Enabled the ability to disable k-input for text display purposes only.

Local Tests

To test the new additions all of the UI elements were used.

Note

Replace .kytos file extension with .vue.
Incorporate changes from drafts in other napps for vue3-sfc-loader compatibility.

@HeriLFIU HeriLFIU changed the title UI/vue3sfcloader modifications Replace httpvueloader with vue3-sfc-loader Oct 21, 2024
@HeriLFIU
Copy link
Collaborator Author

@viniarck I just finished testing all of the k-toolbars, and they are now functioning properly. There's a small error that I fixed, but it was a bit hard to detect. I believe that I got them all, but there is a change that I missed a couple, and unless explicitly used, it won't pop up. The error is that variables now need to be properly declared using either let or var; if not, the vue3-sfc-loader will throw an error. A lot of variables were missing that let/var.

@HeriLFIU
Copy link
Collaborator Author

But I went through all the buttons and inputs and it didn't show up again, so I think that the k-toolbars are in the clear.

@viniarck viniarck requested a review from rmotitsuki October 31, 2024 16:10
Copy link
Member

@viniarck viniarck left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@HeriLFIU, excellent how it's shaping up and having vue3-sfc-loader.

I've made some comments, trivial stuff though. Other than that, quoting that you pointed out:

The error is that variables now need to be properly declared using either let or var; if not, the vue3-sfc-loader will throw an error. A lot of variables were missing that let/var.

This part of non declared vars, have they been handled in other PRs or is this still future work that needs to be done? Let's keep that in mind before marking this PR ready and then we can try to land the changes. Thanks, Heriberto.

src/components/kytos/inputs/Input.vue Show resolved Hide resolved
src/components/kytos/napp/Toolbar.vue Outdated Show resolved Hide resolved
@HeriLFIU
Copy link
Collaborator Author

HeriLFIU commented Nov 1, 2024

@viniarck Yep, I am handling them in the individual PRs for each napp.

@HeriLFIU
Copy link
Collaborator Author

HeriLFIU commented Nov 1, 2024

@viniarck Also, the k-toolbars only had a few errors, which meant they were easy to fix, but the CSS for some of the info panels seems to break for some reason, and I'm trying to find out why.

@viniarck
Copy link
Member

viniarck commented Nov 4, 2024

@viniarck Yep, I am handling them in the individual PRs for each napp.

Excellent. The ones that could've got merged and wouldn't break anything I went ahead and merged them.

When this PR here is ready for review, I recommend you to also list in the description the other depends PR/issues that also need to land just so we make sure to merge them all together, to avoid potentially leaving something behind or potentially broken on master branch.

@viniarck
Copy link
Member

viniarck commented Nov 4, 2024

@viniarck Also, the k-toolbars only had a few errors, which meant they were easy to fix, but the CSS for some of the info panels seems to break for some reason, and I'm trying to find out why.

Right.

@HeriLFIU HeriLFIU force-pushed the UI/vue3sfcloaderModifications branch from 90e039f to e03b62d Compare December 2, 2024 21:30
@HeriLFIU HeriLFIU marked this pull request as ready for review December 9, 2024 15:47
@HeriLFIU HeriLFIU requested a review from a team as a code owner December 9, 2024 15:47
@HeriLFIU HeriLFIU force-pushed the UI/vue3sfcloaderModifications branch from e03b62d to add1c9c Compare December 9, 2024 16:29
@HeriLFIU HeriLFIU force-pushed the UI/vue3sfcloaderModifications branch from d0b9dde to 0b896cc Compare December 17, 2024 17:12
Copy link
Member

@viniarck viniarck left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@HeriLFIU, great work, fantastic contribution. It's almost there. I'll leave the main review to @rmotitsuki, other than that, nice to see vue3-sfc-loader being added without having to change its source code too.

Good compromise supporting only .vue files from now on. But, regarding this point:

We can start leaving the PRs pre-approved and then strategically merge when we got them all ready. Same idea as we're doing with your customClass PRs. Please sync with @rmotitsuki to prioritize the reviews and coordinate this, we're close to holiday season, so let's try to merge this in early/mid January when it's appropriate. OK?

Once again, nicely done.

src/components/kytos/napp/ActionMenuItem.vue Show resolved Hide resolved

const res = await fetch(url);
if (!res.ok)
throw Object.assign(new Error(url + ' ' + res.statusText), { res });
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Did you have the chance to see this throw in practice when developing and exploring it? I'm wondering if it ever happens if it'll be obvious to spot or not

@HeriLFIU
Copy link
Collaborator Author

HeriLFIU commented Jan 9, 2025

There are a few tiny bugs that I found and created issues for, but I was able to switch the UI to Vue JS 3 and had no big issues or errors while using it.

@HeriLFIU
Copy link
Collaborator Author

HeriLFIU commented Jan 9, 2025

This is with all of the most recent fixes, there are still a couple yet to be approved and merged though.

@viniarck
Copy link
Member

viniarck commented Jan 21, 2025

This is with all of the most recent fixes, there are still a couple yet to be approved and merged though.

Cool. Let's try to link which ones are related @HeriLFIU, just so when they land or get fixed then @rmotitsuki can do a final pass review here too. Thanks, Heriberto.

@HeriLFIU
Copy link
Collaborator Author

@viniarck Np, the PRs related to vue3 that were left are:
kytos-ng/pathfinder#87
#124
kytos-ng/maintenance#109
But they have all been approved.
Should I merge the two PRs relating to .set()?
Even though they only function in vue3, and not vue2.

@viniarck
Copy link
Member

viniarck commented Jan 21, 2025

@viniarck Np, the PRs related to vue3 that were left are: kytos-ng/pathfinder#87 #124 kytos-ng/maintenance#109 But they have all been approved. Should I merge the two PRs relating to .set()? Even though they only function in vue3, and not vue2.

I see @HeriLFIU, I think so, check out this comment #124 (comment). But, then as usual, just give a heads to the development team in the slack channel to build the new UI as they pull the latest changes. I think we're at a inflection point that we'll need to land these changes, when they can land together. If you and Rogerio or anyone else from the team had decided on another approach let me know, otherwise let's keep moving forward and landing them.

@HeriLFIU
Copy link
Collaborator Author

@viniarck Sounds good, ill merge them. We hadn't decided on another approach and since the UI changes haven't shown any issues I think we will be done soon.
On a second note, I was able to compile the UI using Vite.
image
image

And it was able to detect some additional issues with the UI, small ones, but I don't know if they are Vite-specific issues or general; since I switched the compat layer to mode 3 and got no errors, I think they are just related to Vite, though.

@HeriLFIU
Copy link
Collaborator Author

I sadly haven't gotten it to load as of yet, because the browser keeps telling me that it does not support export statements, and the bundle has them, so I'm trying to find out what the issue is.

@viniarck
Copy link
Member

Cool @HeriLFIU. Fantastic to see it's being built with Vite, despite still a few minor issues remaining. Feel free to map another issue just for that part, or if it's small enough that can be solved in an existing PR then no need. It's up to you, whichever facilitates to understand what's needs to be done.

I sadly haven't gotten it to load as of yet, because the browser keeps telling me that it does not support export statements, and the bundle has them, so I'm trying to find out what the issue is.

Right

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Watching arrays and objects Components can no longer be registered globally
2 participants