-
Notifications
You must be signed in to change notification settings - Fork 21
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
Port of MarkdownTag to a WebComponent #7
base: main
Are you sure you want to change the base?
Conversation
Added Documentation Added Local Script Copy Fallbacks
- Modified WebComponent - Added usage of nested textarea element for stopping XSS (Likely to be reverted, easily bypassed) - Added MdTagDebugger - built-in debugger for easily debugging WebComponent at runtime.
Modified and updated Documentation. Added XSS Vulnerability Tester. Updated README Updated to-do
… MarketingPipeline-main
@DarkenLM - would you be willing to take on this feature request / to-do list job? Support code syntax highlighting for GFM I created this demo repo https://marketingpip.github.io/Syntax_Demo/ to go off creating a JS function for - when done looking at the demo please let me know so I can delete the repo. For all content inside If willing to do this let me know - tho, you've already more than out done yourself on these commits. Excited to push them ASAP once we make some final decision's for next version of the project & continue make this project even better for the community. |
PS - if you're willing to do this - I'll try to organize the rest of the GitHub Markdown Flavour CSS in the mean time to provide you with! |
Notice for this PR - we need to test script loading / payload times via SEO audits etc. Currently times pass acceptable times for SEO score. Plus to improve things - styles should not be applied in-line but to body head to improve SEO on page. As of right now they are NOT in current version of Markdown Tag and is currently slightly affecting page scores. |
The reason stylesheets are loaded into the shadow DOM is to provide encapsulation, allowing for each MarkdownTag instance to be affected exclusively by it's own properties, however, I think I can add the stylesheets to the body head, as due to the stylesheet only applying styles to |
Don't know how I missed this! But yes - adding to the head is a better solution! Was playing with some things for syntax highlighting. Don't know why I suggest that poor option for highlighting before - we should be using the same style for GitHub uses so content can be highlighted and non highlighted like so GitHub Hightlight Example
And a better resource then what I posted before - my apologizes in advanced! |
@DarkenLM @shaunbharat - again my apologizes. Marked already has highlighter options & Showdown has a plugin that we can add in. So no need to build these options from the ground up. Using Advanced - Marked Documentation Showdown Highlight: A Showdown extension for highlighting code blocks. |
@DarkenLM @shaunbharat - playing around again & https://github.com/PrismJS/prism does auto-detection on page already in same format as GitHub. This will be the option we will add in. Literally can just be added into the script. |
@MarketingPip when will the syntax highlighting feature be implemented? |
@AR-Student824 - hoping to go over some options before implementing this PR request to see if possible to keep the For now you can currently add https://github.com/PrismJS/prism to your web page tho & it will work! |
@DarkenLM - can I ask you to change the file structure of this branch to match the following? Example:
As well possibility the "tests" folder moved into
As well @shaunbharat - is there any changes to grammar, README etc that you might want to commit if you have not already? |
Will do as soon as I can. Also, was the Github CSS file modified lately? It seems to be broken suddenly. Sorry for the edits. Found the bug. github-md h1, h2, h3 to github-md h1, github-md h2, github-md h3 solves the problem. |
Updated WebComponent Updated File Strucutre
@MarketingPip Done. Added a build script for convenience using UglifyJS. |
@MarketingPip I can open a PR for the changes I have at the moment, but I haven't made any new major changes in a while Currently, I just have minor improvements to the readme - @DarkenLM can I just open a PR for your fork? |
@DarkenLM - not that I know of? It appears CSS is working fine on my end for GitHub style sheet without those changes applied. Two things tho - assuming you have tested your HTML Sanitizer functions with more than one test? As some sanitizers will sanitize TOO much content & mess things up. Tho ShowDown does have a sanitizer built in (correct me if wrong) - just doesn't work 100% correctly. As well assuming you have looked into using Prism JS in your fork as it provides support for syntax highlighting? Tho keep in mind we do need to find a good CSS theme for Prism JS that is as close to the GitHub syntax highlighting color styles. Maybe this is something you can overlook for options @shaunbharat? When you think thing's are finally ready @DarkenLM - please provide some test suites so we can keep this project more professional going fourth. If needed - I can write some basic one's up when you have thing's ready. @shaunbharat - I will ask you to review the options avaliable for CSS themes, as well over look any grammar / spelling / improvements that can be made in DarkenLM's fork. And if willing / able - review the code pushed, see if anything sticks out to you that might need changed. As well do some live tests to make sure thing's are working smoothly (I will do the same tasks as well) & once we have confirmed thing's are ready. I will accept the pull request with the updated changes! 🎉 Let's get this done sooner than later! 👍 ps; Thank you both for your commitment to this project! And hope you are both doing more than well! |
@DarkenLM - have not personally done a usage test of your fork but your code is more than GOLD 🥇 Was over-looking your XSS test suite as well - and am more than likely assuming I should be leaving the test suites to you at this time. 😆 Tho I can provide some basic one's. Few thing's I wanted to address one being a small one - assuming this was typo or short form for "Assert". But thinking we should change the following debug line's here lol!
to
Second thing regarding file paths in repo we will need to move the stylesheets folder to
Third thing - assuming this was a typo error etc. But in the README you do not have HTML decoding checked off...? Tho I will want to be going through the README & provide some changes based on github.com/MarketingPipeline repo style's & make some improvements to it as well / remove some un-necessary bits. And then I will have @shaunbharat review it for grammar + suggest any changes & you can follow up from there. Plus one extra thing - we can remove the I do believe @shaunbharat has already went through the docs and made improvements tho as well - but maybe @shaunbharat wants to add something after personal use-age of the updated version etc that user's might find useful etc. We're so close to releasing this update 🥳 |
@DarkenLM as well for indentation issue / improvement. Do not know if this would be a capable fix but as you said - maybe we could get first character in line and move all content under first character to the left side of HTML document automatically. Example :
would automatically become
Moving all content to left like so. I don't know if counting characters to remove based on the white space of first character is best idea to go about doing this or if there is some kind of align like library / feature we can use that exists already for this (that will not mess with user content). |
That
The build script already copies any non-source file to it's respective place on the
Will do
I didn't touch the README too much, just enough to explain my changes and provide an easy way to understand them.
Will do.
You are a very lucky man. I made a function to dedent strings some hours ago, but completely forgot MarkdownTag required it. |
@DarkenLM figured you'd get a laugh too! Doing some tests on my end here - on iPhone 5S (don't laugh bout that either lol) The documentation example does not load. Have not tested if only the documentation or if this web component does not load properly at all on Mobile Devices. Image attached for reference. As for the file path builds - you mentioned the files are moved upon build tho I would like to move them just to keep the repo structure as clean as possible. Regarding this as well - maybe you can give me a refresher but is there not a way to link different repos / branches in the same repo via a folder? (On click of folder on GitHub.com it redirects to another branch) I thought GitHub had this feature but I can't recall how to do it, just thinking as much as I would like to keep all the versions together in one main branch. If this project ever does have future versions, for someone to download the source code they would literally be downloaded every version produced (which is NOT ideal obviously) And haha that's just our intuition speaking 😄 But correct - very lucky that you had that already done, as well more than lucky to have you + @shaunbharat collaborating on the project in general Excited to see where this could become in the future! ps; @DarkenLM - don't know if you read the ShowDown docs / README page lately. But they did add some more flavour values (that I did not see previously before). You might want to make a call to remove a parser and replace it with showdown to make the script smaller - tho I will leave that judgement call up to you & you solely. |
@DarkenLM - confirming issue on iOS 13 with this PR. Script does NOT load properly (script id's for parser are not placed in document) on iOS 13 / Apple iPhone. Can not confirm for other devices. |
The only thing I can remember are git submodules, but I am not that familiar with them either.
The script downloads the files as they are needed, so it's not that big of a deal, fortunately.
Well that is unfortunate, as I have no idea what is failing. I know Apple does not like to follow standards, but for what I checked, all API calls used are supported by Safari. |
@DarkenLM - I would assume this has something to do with the web component. As the tag version (current version) works with mobile rendering. I will have to do some test to confirm later on this tho some input would be more than appreciated. |
Leaving this here as well. CSS stylesheet needed for this project: |
@DarkenLM - confirming on iOS 13 there is no support for basic web components. We will need to add a fix for this and then should be able to merge this PR. I will be working on new documentation ASAP that falls under open source license so no conflicting license's with this repo. Tho you are going to hate me - as I found a similar project to this one & they are already using method that requires a fix for FOUC before rendering. Which again - wondering if we could possibly use this method & keep the Edit: Correcting myself, it appears constructed style sheets do not work. Tho the current version of Markdown-Tag does work on iOS 13. |
@DarkenLM - my apologizes for leaving this hanging so long! I still want to add this to the branch / repo! I did find the correct polyfills needed for the web component. Tho I would still like to address some things / then make this happen! Hope you're still on-board + @shaunbharat is as well to get this merged 👌 sorry for any delays on my part guys! |
I'm still onboard and would like to help wherever I can! I started my school year a while back though, so I haven't even touched a code editor for a while. |
I definitely want to keep contributing to this repo. Unfortunately, my university also started, so my free time is greatly reduced, so contributions might be slower. |
Ported MarkdownTag to a WebComponent. Allows for a single script to use all three parsers.
Added documentation for MarkdownTag.
Fixed XSS Vulnerability, as far as the DOM Structure allows to.
Added XSS Vulnerability Tester.
Fixes #5