123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145 |
- import Delta from 'quill-delta';
- import Quill from '../core/quill';
- import Module from '../core/module';
- import {
- TableCell,
- TableRow,
- TableBody,
- TableContainer,
- tableId,
- } from '../formats/table';
- class Table extends Module {
- static register(options) {
- Quill.register(TableCell, options);
- Quill.register(TableRow, options);
- Quill.register(TableBody, options);
- Quill.register(TableContainer, options);
- }
- constructor(...args) {
- super(...args);
- this.listenBalanceCells();
- }
- balanceTables() {
- this.quill.scroll.descendants(TableContainer).forEach(table => {
- table.balanceCells();
- });
- }
- deleteColumn() {
- const [table, , cell] = this.getTable();
- if (cell == null) return;
- table.deleteColumn(cell.cellOffset());
- this.quill.update(Quill.sources.USER);
- }
- deleteRow() {
- const [, row] = this.getTable();
- if (row == null) return;
- row.remove();
- this.quill.update(Quill.sources.USER);
- }
- deleteTable() {
- const [table] = this.getTable();
- if (table == null) return;
- const offset = table.offset();
- table.remove();
- this.quill.update(Quill.sources.USER);
- this.quill.setSelection(offset, Quill.sources.SILENT);
- }
- getTable(range = this.quill.getSelection()) {
- if (range == null) return [null, null, null, -1];
- const [cell, offset] = this.quill.getLine(range.index);
- if (cell == null || cell.statics.blotName !== TableCell.blotName) {
- return [null, null, null, -1];
- }
- const row = cell.parent;
- const table = row.parent.parent;
- return [table, row, cell, offset];
- }
- insertColumn(offset) {
- const range = this.quill.getSelection();
- const [table, row, cell] = this.getTable(range);
- if (cell == null) return;
- const column = cell.cellOffset();
- table.insertColumn(column + offset);
- this.quill.update(Quill.sources.USER);
- let shift = row.rowOffset();
- if (offset === 0) {
- shift += 1;
- }
- this.quill.setSelection(
- range.index + shift,
- range.length,
- Quill.sources.SILENT,
- );
- }
- insertColumnLeft() {
- this.insertColumn(0);
- }
- insertColumnRight() {
- this.insertColumn(1);
- }
- insertRow(offset) {
- const range = this.quill.getSelection();
- const [table, row, cell] = this.getTable(range);
- if (cell == null) return;
- const index = row.rowOffset();
- table.insertRow(index + offset);
- this.quill.update(Quill.sources.USER);
- if (offset > 0) {
- this.quill.setSelection(range, Quill.sources.SILENT);
- } else {
- this.quill.setSelection(
- range.index + row.children.length,
- range.length,
- Quill.sources.SILENT,
- );
- }
- }
- insertRowAbove() {
- this.insertRow(0);
- }
- insertRowBelow() {
- this.insertRow(1);
- }
- insertTable(rows, columns) {
- const range = this.quill.getSelection();
- if (range == null) return;
- const delta = new Array(rows).fill(0).reduce(memo => {
- const text = new Array(columns).fill('\n').join('');
- return memo.insert(text, { table: tableId() });
- }, new Delta().retain(range.index));
- this.quill.updateContents(delta, Quill.sources.USER);
- this.quill.setSelection(range.index, Quill.sources.SILENT);
- this.balanceTables();
- }
- listenBalanceCells() {
- this.quill.on(Quill.events.SCROLL_OPTIMIZE, mutations => {
- mutations.some(mutation => {
- if (['TD', 'TR', 'TBODY', 'TABLE'].includes(mutation.target.tagName)) {
- this.quill.once(Quill.events.TEXT_CHANGE, (delta, old, source) => {
- if (source !== Quill.sources.USER) return;
- this.balanceTables();
- });
- return true;
- }
- return false;
- });
- });
- }
- }
- export default Table;
|