All browsers that support the User-Agent Client Hints API (Chrome 89+, Edge 89+, Opera 75+)
The build process is managed using Vite. To build the package, run the following command:
npm run build
The example app is built and runs on Vite.
npm run example
The project also includes proper configuration files for TypeScript, ESLint, Prettier, and Vite for development and building.
ASCII tree diagram of the project structure:
SortableTS/
├── src/
│ ├── animation/
│ │ ├── animation.interfaces.ts
│ │ ├── animation.ts
│ │ └── animation.utils.ts
│ ├── core/
│ │ ├── state.ts
│ │ ├── sortable.interfaces.ts
│ │ ├── sortable.readme.md
│ │ ├── sortable.ts
│ │ └── store.ts
│ ├── dom/
│ │ ├── dom.utils.ts
│ │ ├── event.interfaces.ts
│ │ ├── event.ts
│ │ └── events.utils.ts
│ ├── utils/
│ │ ├── array.ts
│ │ ├── browser.ts
│ │ ├── element.utils.ts
│ │ └── math.ts
│ ├── global.interfaces.ts
│ └── index.ts
├── example/
├── .editorconfig
├── .eslintignore
├── .eslintrc.json
├── .gitignore
├── .prettierignore
├── .prettierrc
├── package.json
├── package-lock.json
├── readme.md
├── tsconfig.json
└── vite.config.ts
expando is now instance in src/core/store.ts
const instance = sortable || getInstance(rootEl);
if (!instance) {
throw new Error('No Sortable instance found');
}
Changed static ghost to preview
Renamed _createGhost to _createPreview
Changed ghost-related methods to _hideDraggingEl, _showDraggingEl, _appendDraggingEl