{"id":36499319,"url":"https://github.com/yamogoo/resize-bounding","last_synced_at":"2026-03-14T10:01:35.284Z","repository":{"id":247391687,"uuid":"818800371","full_name":"yamogoo/resize-bounding","owner":"yamogoo","description":"Highly customizable Vue3/React component for resizing nested content","archived":false,"fork":false,"pushed_at":"2025-09-25T11:04:24.000Z","size":6117,"stargazers_count":7,"open_issues_count":0,"forks_count":0,"subscribers_count":1,"default_branch":"main","last_synced_at":"2025-09-25T13:07:38.127Z","etag":null,"topics":["bounding","bounding-box","draggable","draggable-panel","react-resize-bounding","react-resizer","resizer","resizer-block","ui-component","vue3-resize-bounding","vue3-resizer"],"latest_commit_sha":null,"homepage":"https://resize-bounding.netlify.app/","language":"TypeScript","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"mit","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/yamogoo.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":"LICENSE","code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null,"zenodo":null,"notice":null,"maintainers":null,"copyright":null,"agents":null,"dco":null,"cla":null}},"created_at":"2024-06-22T22:53:35.000Z","updated_at":"2025-09-25T11:03:53.000Z","dependencies_parsed_at":"2024-08-22T07:41:36.733Z","dependency_job_id":"d8e143da-8107-47a9-9604-0eaa2d2f1643","html_url":"https://github.com/yamogoo/resize-bounding","commit_stats":null,"previous_names":["yamogoo/vue3-resize-bounding","yamogoo/resize-bounding"],"tags_count":17,"template":false,"template_full_name":null,"purl":"pkg:github/yamogoo/resize-bounding","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/yamogoo%2Fresize-bounding","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/yamogoo%2Fresize-bounding/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/yamogoo%2Fresize-bounding/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/yamogoo%2Fresize-bounding/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/yamogoo","download_url":"https://codeload.github.com/yamogoo/resize-bounding/tar.gz/refs/heads/main","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/yamogoo%2Fresize-bounding/sbom","scorecard":null,"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":286080680,"owners_count":28331882,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2026-01-12T00:36:25.062Z","status":"online","status_checked_at":"2026-01-12T02:00:08.677Z","response_time":98,"last_error":null,"robots_txt_status":"success","robots_txt_updated_at":"2025-07-24T06:49:26.215Z","robots_txt_url":"https://github.com/robots.txt","online":true,"can_crawl_api":true,"host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["bounding","bounding-box","draggable","draggable-panel","react-resize-bounding","react-resizer","resizer","resizer-block","ui-component","vue3-resize-bounding","vue3-resizer"],"created_at":"2026-01-12T02:16:50.314Z","updated_at":"2026-03-14T10:01:35.276Z","avatar_url":"https://github.com/yamogoo.png","language":"TypeScript","funding_links":[],"categories":[],"sub_categories":[],"readme":"![image](/shared/images/resize-bounding-w-descriptor.svg)\n\n![image](https://github.com/yamogoo/resize-bounding/blob/v.2.1.0/shared/images/resize-bounding.gif)\n\n**Resize Bounding** is a simple component for Vue3/React that allows you to intuitively resize nested content using draggable border panels.\n\n[Demo](https://resize-bounding.netlify.app/)\n\n|                                         | Package name                                                             | Installation                  | Links                                                                                                                                                                                                                                                                                                           | Version / License                                                                                                                             |\n| --------------------------------------- | ------------------------------------------------------------------------ | ----------------------------- | --------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | --------------------------------------------------------------------------------------------------------------------------------------------- |\n| ![image](/shared/images/vue-logo.svg)   | [Vue3 Resize Bounding](/packages/vue/vue3-resize-bounding/README.md)     | `npm i vue3-resize-bounding`  | [Documentation](https://vue3-resize-bounding-docs.netlify.app/?path=/story/sandbox-examples--cover)\u003c/br\u003e[Example](https://stackblitz.com/edit/vue3-resize-bounding-example?file=src%2FApp.vue)\u003c/br\u003e[Repository](https://github.com/yamogoo/resize-bounding/tree/v.2.1.0/packages/vue/vue3-resize-bounding)      | ![Version](https://img.shields.io/badge/version-2.1.4-green) [![License: MIT](https://img.shields.io/badge/License-MIT-green.svg)](./LICENSE) |\n| ![image](/shared/images/react-logo.svg) | [React Resize Bounding](/packages/react/react-resize-bounding/README.md) | `npm i react-resize-bounding` | [Documentation](https://react-resize-bounding-docs.netlify.app/?path=/story/sandbox-examples--cover)\u003c/br\u003e[Example](https://stackblitz.com/edit/react-resize-bounding-example?file=src%2FApp.tsx)\u003c/br\u003e[Repository](https://github.com/yamogoo/resize-bounding/tree/v.2.1.0/packages/react/react-resize-bounding) | ![Version](https://img.shields.io/badge/version-1.1.2-blue) [![License: MIT](https://img.shields.io/badge/License-MIT-blue.svg)](./LICENSE)   |\n| ![image](/shared/images/figma-logo.svg) | Design UI Component                                                      |                               | [Figma](https://www.figma.com/community/file/1392603830584852243)                                                                                                                                                                                                                                               | [![License: MIT](https://img.shields.io/badge/License-CCBY4.0-red.svg)](https://creativecommons.org/licenses/by/4.0/)                         |\n\n---\n\n**Vue3 Usage**\n\n```html\n\u003c!-- @filename: MyComponent.vue --\u003e\n\u003cscript setup lang=\"ts\"\u003e\n  import { ref } from \"vue\";\n  import ResizeBounding from \"vue3-resize-bounding\";\n\n  const container = ref({ width: 320, height: 480 });\n\u003c/script\u003e\n\n\u003ctemplate\u003e\n  \u003cResizeBounding\n    :width=\"container.width\"\n    :height=\"container.height\"\n    :min-width=\"240\"\n    :max-width=\"480\"\n    :min-height=\"120\"\n    :directions=\"'hv'\"\n    :options=\"{\n        position: 'central',\n        splitterWidthNormal: 1,\n        splitterWidthActive: 4,\n        knob: {\n          show: true\n        }\n    }\"\n    :style=\"{ border: '1px solid gray' }\"\n    @update:width=\"(width) =\u003e (container.width = width)\"\n    @update:height=\"(height) =\u003e (container.height = height)\"\n  \u003e\n    \u003c!-- CONTENT START --\u003e\n    \u003cdiv :style=\"{ width: '100%', height: '100%' }\"\u003eMy Container\u003c/div\u003e\n    \u003c!-- CONTENT END --\u003e\n\n    \u003c!-- KNOB INNER CONTENT START --\u003e\n    \u003ctemplate #knob\u003e\n      \u003cdiv class=\"some-icon\"\u003e\u003c/div\u003e\n    \u003c/template\u003e\n    \u003c!-- KNOB INNER CONTENT END --\u003e\n  \u003c/ResizeBounding\u003e\n\u003c/template\u003e\n```\n\n**React Usage**\n\n```tsx\n// @filename: MyComponent.tsx (.js)\nimport { useState } from \"react\";\nimport ResizeBounding from \"react-resize-bounding\";\n\nexport default function App() {\n  const [width, setWidth] = useState(320);\n  const [height, setHeight] = useState(480);\n\n  return (\n    \u003cResizeBounding\n      width={width}\n      height={height}\n      directions=\"hv\"\n      updateWidth={(width) =\u003e setWidth(width)}\n      updateHeight={(height) =\u003e setHeight(height)}\n      style={{ border: \"1px solid gray\" }}\n      options={{\n        knob: {\n          show: true,\n        },\n      }}\n    \u003e\n      {/* CONTENT START */}\n      \u003cdiv style={{ width: \"100%\", height: \"100%\" }}\u003eMy Container\u003c/div\u003e\n      {/* CONTENT END */}\n    \u003c/ResizeBounding\u003e\n  );\n}\n```\n\n---\n\n## License\n\nLicensing is in accordance with the original.\n\n[MIT](https://github.com/yamogoo/resize-bounding/blob/main/LICENSE)\n\n## Author\n\n**Mikhail Grebennikov** - [yamogoo](https://github.com/yamogoo)\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fyamogoo%2Fresize-bounding","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fyamogoo%2Fresize-bounding","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fyamogoo%2Fresize-bounding/lists"}