New Case Study:See how Anthropic automated 95% of dependency reviews with Socket.Learn More
Socket
Sign inDemoInstall
Socket

gridchen

Package Overview
Dependencies
Maintainers
1
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

gridchen

Very lightweight and fast editable web grid with strict MS-Excel adherence to user experience.

  • 0.1.5
  • PyPI
  • Socket score

Maintainers
1

About

Very lightweight and fast editable web grid with strict MS-Excel adherence to user experience. Modern as of year 2020 (web components, es6 modules) with no dependencies.

If you need to edit mixed hierarchical and grid data, please visit sister project form-chen.

Demos, PlayGrounds and Documentation

See gridchen at github.io

Installation

Either

  • Use a CDN such as
  • or git-clone a release
  • or copy the gridchen module folder
  • or pip install gridchen
  • or npm install gridchen

Releases

All stable releases are tagged.

Basic Usage

<!DOCTYPE html>
<grid-chen></grid-chen>
<script type="module">
    import "https://decatur.github.io/gridchen/gridchen/webcomponent.js"
    import {createView} from "https://decatur.github.io/gridchen/gridchen/matrixview.js"
    import {createTransactionManager} from "https://decatur.github.io/gridchen/gridchen/utils.js";

    // The JSON schema defines the data structure of the matrix.
    const schema = {
        title: 'Array of Row Arrays',
        type: 'array',
        items: {
            type: 'array',
            items: [
                {title: 'SomeDate', type: 'string', format:'full-date'},
                {title: 'SomeNumber', type: 'number'}
            ]
        }
    };

    const rows = [['2019-01-01', 1], ['2020-01-01', 2], ['2021-01-01', 3]];
    const view = createView(schema, rows);
    const tm = createTransactionManager();
    document.querySelector('grid-chen').resetFromView(view, tm);
</script>

Expected Behaviour

We try to mimic MS-Excel as close as possible.

Supported Keyboard Shortcuts

See also Keyboard shortcuts in Excel

KeyAction
Ctrl+ZUndo last transaction
Ctrl+YRedo, reverse last undo
ArrowsMove active cell up/down/left/right (not in edit mode)
TabMove active cell right (non-rolling)
EnterMove active cell down (non-rolling)
Shift+EnterMove active cell up (non-rolling)
Shift+TabMove active cell left (non-rolling)
SHIFT+ArrowsSelect a range of cells
Ctrl+SpaceSelect entire column
Shift+SpaceSelect entire row
Shift+MouseClickExpand selection
Ctrl+MouseClickMulti-select cells
Ctrl+'-'Delete selected row
Ctrl+'+'Insert row before selection
Alt + EnterIn edit mode, insert newline
Page DownMove one page down
Page UpMove one page up
Ctrl+ASelect all grid cells (same as Ctrl+A in an Excel List Object)
Ctrl+A Ctrl+ASelect the entire grid including header (same as Ctrl+A Ctrl+A in an Excel List Object)
ESCCancel edit or input mode
DeleteRemove selected cells contents
Ctrl+CCopy selected cells to clipboard
Ctrl+VPaste clipboard into selected cells
Ctrl+XCut
F2Enter edit mode; In input or edit mode, toggle between input and edit.
Alt+F1Open a modal chart of the selection.
BackspaceIn input or edit mode, deletes one character to the left
DeleteIn input or edit mode, deletes one character to the right
EndIn input or edit mode, move to the end of the text
HomeIn input or edit mode, move to the beginning of the text

Light / Dark Mode

gridchen has a light and dark mode. The desired mode is sniffed through the background color intensity of the body element. There are currently no other explicit CSS hooks, such as CSS custom properties.

⚠ Some dark reader (for example Dark Reader) extensions may show inferior results when converting light to dark mode than gridchen's native dark mode.

Undo & Redo

tm

TODOs

  • Do not use JSON Patch replace for a remove operation!
  • TransactionManager: Do not add properties cell to patch array.
  • Handle clipboard not permitted errors
  • Improve encapsulation of JavaScript API
  • Show 1 empty row at end (Slider issue)
  • Avoid refreshing complete viewport on cell change
  • Handling of Infinity and NaN (#NV in de-de)

Contribute

Publish as Python Package

Bump version in setup.py and git tag.

python setup.py sdist bdist_wheel
python -m twine upload dist/*

Publish as npm Package

Bump version in gridchen/package.json and git tag.

cd gridchen & npm publish

Alternatives

About JavaScript Modules

As gridchen has no dependencies, we do not need any packaging or use of bare import spec remapping like Skypack

See

FAQs


Did you know?

Socket

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.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc