3.5.3.2. «Страница» и «Таблица»

Описание статической таблицы выглядит следующим образом

{
    "id": "simple-table",                 // идентификатор компонента
    "type": "table",                      // тип компонента
    "config": {
        "fixedLayout": false,             // фиксированная разметка
        "format": "${salary} - ${amount}",// форматная строка
        "delimeter": ""                   // разделитель свертки
    },
    "properties": [],                     // массив компонентов, так же как в форме
    "layout": {},                         // разметка, так же как в форме
    "style": {                            // стиль компонента
        "border": "1",                    // отображать границы
        "wrap": true                      // выводить содержимое в виде абзаца
    }
}

Описание динамической таблицы выглядит следующим образом

{
    "id": "table-id",       // идентификатор компонента
    "type": "table",        // тип компонента
    "config": {
        "appendRows": true,   // добавлять строки в режиме заполнения
        "init-row": 2,        // количество отображаемых строк при создании
        "fixedLayout": false, // фиксированная разметка
        "isHaveHeaders": true // добавить заголовок таблицы
    }
    "properties": [],       // массив компонентов, так же как в форме
    "layout": {},           // разметка, так же как в форме
    "style": {
        "border": "1",      // отображать границы
        "wrap": true        // выводить содержимое в виде абзаца
    }
}

Модель данных динамической таблицы

{
    "id": "person-list",                // идентификатор компонента
    "type": "appendable_table",         // тип компонента
    "key": "значение свертки таблицы",
    "data": [{                          // массив данных таблицы
        "id": "person-b1",              // компонент person в первой строке таблицы
        "type": "textbox",
        "value": "Иванов Иван"
    },
    {
        "id": "age-b1",                 // компонент age в первой строке таблицы
        "type": "numericinput",
        "value": "23",
        "key": "23"
    },
    {
        "id": "person-b2",              // компонент person во второй строке таблицы
        "type": "textbox",
        "value": "Сериков Серик"
    },
    {
        "id": "age-b2",                 // компонент age во второй строке таблицы
        "type": "numericinput",
        "value": "25",
        "key": "25"
    }
    ]
}

Примечание

Компоненты внутри таблицы имеют идентификаторы, т.к. таблица может иметь несколько блоков, чтобы идентификаторы не дублировались добавляется постфикс -bN, где N номер блока таблицы, нумерация блоков начинается с 1. Например, если компонент в таблице имеет идентификатор cmp, то значения идентификаторов для блоков будут иметь вид cmp-b1, cmp-b2 и т.д. Окончание -bN должно иметь одинаковый номер N для компонентов одного блока.


class AS.FORMS.TableModel()

Модель компонентов «Страница» и «Таблица»

bus

Дополнительные типы событий

tableRowAdd - событие добавления блока в дин таблицу

Object event: возникшее событие

AS.FORMS.TableModel() model: модель проигрывателя

массив AS.FORMS.TableModel() models: модели добавленного блока дин таблицы

tableRowDelete - событие удаления блока дин таблицы
Object event: возникшее событие
getBlockNumbers()
Результат:массив с номерами блоков дин таблицы, поскольку блоки из дин таблицы удаляются и добавляются, то номер блоков идут не по порядку, например [1, 5, 6, 8] и это не будет ошибкой
getModelWithId(cmpId[, tableId[, blockNumber])

Получить модель компонента по его идентификатору

param String cmpId:
 идентификатор компонента
param String tableId:
 идентификатор динамической таблицы
param Number blockNumber:
 номер блока динамической таблицы
returns:AS.FORMS.Model()
createRow()

Добавляет блок таблицы

removeRow(blockIndex)

Удаляет блок таблицы

Аргументы:
  • blockNumber (Number) – индекс блока дин таблицы (по порядку)
removeRowByBlockNumber(blockNumber)

Удаляет блок таблицы

Аргументы:
  • blockNumber (Number) – номер блока дин таблицы
getTextValue()

Возвращает форматированное значение свертки

Результат:значение свертки
isHaveHeader()

Наличие заголовка

isPage()

Является страницей

isStatic()

Является статической таблицей

isParagraph()

Свертка включена


class AS.FORMS.TableStaticView()

Отображение статической таблицы или страницы

getRowsCount()

Возвращает количество рядов таблицы, не обязательно равно числу блоков дин таблицы, посклько блок может состоять из сколько угодно рядов

setColumnVisible(columnNumber, visible)

Делает столбец таблицы видимым / невидимым

Аргументы:
  • columnNumber (Number) – номер столбца
  • visible (boolean) – видимый
getInvisibleColumns()

Возвращает список невидимых столбцов

getViewWithId(cmpId[, tableId[, tableBlockIndex]])

Получение отображения компонента с указанным идентификатором в указанной таблице и указанном блоке, если идентификатор таблицы не указан, то ищется модель компонента на странице или в статических таблицах

Аргументы:
  • cmpId (String) – идентификатор компонента
  • tableId (String) – идентификатор динамической таблицы
  • tableBlockIndex (Number) – номер блока динамической таблицы
Результат:

AS.FORMS.View() отображение компонента

class AS.FORMS.TableDynamicView()

Отображение динамической таблицы

setEnabled(enabled)

Разрешить пользователю добавлять и удалять блоки, при этом программная возможность остается

Аргументы:
  • enabled (boolean) – разрешить добавлять и удалять блоки
setColumnVisible(column, visible)

Сделать столбец таблицы видимым

Аргументы:
  • column (Number) – номер столбца таблицы
  • visible (boolean) – является видимым
getViewWithId(cmpId[, tableId[, tableBlockIndex]])

Получить отображения компонента с указанным идентификатором в указанной таблице и указанном блоке, если идентификатор таблицы не указан, то ищется модель компонента на странице или в статических таблицах

Аргументы:
  • cmpId (String) – идентификатор компонента
  • tableId (String) – идентификатор динамической таблицы
  • tableBlockIndex (Number) – номер строки динамической таблицы
Результат:

object отображение компонента

mergeCell(row, column, rows, cols)

Объединить ячейки в блоке

Аргументы:
  • row (Number) – номер ряда таблицы
  • column (Number) – номер столбца таблицы
  • rows (Number) – количество рядов для объединения
  • cols (Number) – количество столбцов для объединения
splitCell(row, column)

Разъединить ячейки

Аргументы:
  • row (Number) – номер ряда таблицы
  • column (Number) – номер столбца таблицы
class AS.FORMS.TableParagraphView()

Отображение динамической таблицы в свертке