data:image/s3,"s3://crabby-images/2523c/2523ce4b8b64bade795ffc89574cfc29f35428d3" alt="Deno 2.2 Improves Dependency Management and Expands Node.js Compatibility"
Security News
Deno 2.2 Improves Dependency Management and Expands Node.js Compatibility
Deno 2.2 enhances Node.js compatibility, improves dependency management, adds OpenTelemetry support, and expands linting and task automation for developers.
side-panel-menu-thing
Advanced tools
Good option for mobile menus, general content reveals, or whatever else.
https://henrygd.me/side-panel-menu-thing
Touch responsive, easy to implement, fairly lightweight, and MIT licensed. Good option for mobile menus, general content reveals, or whatever else. Tried to mimic a native app menu as much as possible.
dist/side-panel-menu-thing.mjs
dist/side-panel-menu-thing.umd.js
dist/side-panel-menu-thing.min.js
src/side-panel-menu-thing.svelte
$ npm install side-panel-menu-thing
Grab the few lines of CSS from dist/side-panel-menu-thing.css
and add to your styles.
import sidePanel from 'side-panel-menu-thing'
// target and content required, others optional
const menu = sidePanel({
// target container (where it's mounted and listens for touch)
target: document.body,
// panel content (will be removed and added in the panel)
content: document.getElementById('content'),
// width of panel
width: 400,
// open / close animation time
duration: 450,
// fixed to screen
fixed: true,
// open on left
left: false,
// whether to open on touch drag
dragOpen: true,
// runs when the menu is opened (as soon as it's visible)
onShow: () => console.log('showing'),
// runs when the menu is closed (as soon as it's hidden)
onHide: () => console.log('hidden'),
})
// options are accessible / changeable afterward
menu.width
// 400
menu.width = 500
// 500
// show the panel
menu.show()
// hide the panel
menu.hide()
// destroy
menu.$destroy()
If you have a fixed menu set to open on drag, but want disable on a specific element, add a data-no-panel
attribute to the html.
<div class="slider" data-no-panel>
<div class="slide"></div>
<div class="slide"></div>
</div>
No. This was built using Svelte but doesn't require it to use.
If you are using it already in your project, you can import the svelte component rather than the processed bundle. If you're using rollup or webpack, this should happen automatically. Then pass the options in as props, including target, as below.
I will probably release this as a standalone component at some point with a proper slot.
const menu = new sidePanel({
target: document.body,
props: {
target: document.body,
content: document.getElementById('menu'),
},
})
To use with IE, you need some polyfills. Easiest solution is to insert the script below in your html above where you're loading your other scripts. This will load the polyfills only in unsupported browsers.
<script>
if (!('customElements' in window)) {
window.requestAnimationFrame = window.requestAnimationFrame.bind(window)
window.setTimeout = window.setTimeout.bind(window)
document.write(
'<script src="https://cdn.jsdelivr.net/combine/npm/promise-polyfill@8.1.0/dist/polyfill.min.js,npm/classlist-polyfill@1.2.0/src/index.js,npm/mdn-polyfills@5.19.0/Array.prototype.fill.js,npm/@webcomponents/webcomponentsjs@2.4.1/webcomponents-bundle.min.js"><\/script>'
)
}
</script>
MIT
FAQs
Good option for mobile menus, general content reveals, or whatever else.
The npm package side-panel-menu-thing receives a total of 69 weekly downloads. As such, side-panel-menu-thing popularity was classified as not popular.
We found that side-panel-menu-thing demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Deno 2.2 enhances Node.js compatibility, improves dependency management, adds OpenTelemetry support, and expands linting and task automation for developers.
Security News
React's CRA deprecation announcement sparked community criticism over framework recommendations, leading to quick updates acknowledging build tools like Vite as valid alternatives.
Security News
Ransomware payment rates hit an all-time low in 2024 as law enforcement crackdowns, stronger defenses, and shifting policies make attacks riskier and less profitable.