Сохранение параметров грида
Материал из GedeminWiki
(Различия между версиями)
SYSDBA (обсуждение | вклад) (→Таблицы) |
SYSDBA (обсуждение | вклад) |
||
| Строка 24: | Строка 24: | ||
# Для текущего пользователя. | # Для текущего пользователя. | ||
| − | # Если не найден, то для | + | # Если не найден, то для всех пользователей. |
| − | # | + | # Для текущей темы. |
| + | # Если нет, то общие (без темы). | ||
===Таблицы=== | ===Таблицы=== | ||
| + | |||
| + | Скрипты таблиц и сопутствующих триггеров располагаются в файле '''at_attribute.sql'''. | ||
* [[AT_THEME]] | * [[AT_THEME]] | ||
| Строка 42: | Строка 45: | ||
===Диалоговое окно настройки грида=== | ===Диалоговое окно настройки грида=== | ||
| − | + | # Увеличить размер и перекомпоновать с учетом того, что экраны стали больше и нет необходимости разбивать на много вкладок. | |
| + | # Запрос выкинуть (перенести) в окно Свойства объекта. | ||
| + | # Вкладку шаблоны выкинуть. | ||
| + | # Должно быть четко видно для какого пользователя мы настраиваем, для какой темы. | ||
| + | # Должно быть четко видно свойство установлено именно для этой колонки, этого грида, или его значение получилось по иерархии. | ||
| + | # Должна быть возможность как установить значение свойства, так и скинуть его -- тогда будет браться по иерархии. | ||
[[Category:Постановка]] | [[Category:Постановка]] | ||
__NOTOC__ | __NOTOC__ | ||
Версия 01:12, 22 февраля 2016
Разрабатывается система для работы со всеми визуальными настройками платформы, но, в первую очередь, для работы с визуальными настройками гридов.
Сейчас параметры грида хранятся в двоичном потоке, в Хранилище. Причем для каждого грида, для каждой его колонки, сохраняются все параметры вне зависимости от того используются они или нет, отличаются от установленных на уровне колонки таблицы и домена или нет.
Ядром системы будет объект TgdStyleManager, который отвечает за следующие функции:
- Считывание настроек из реляционных таблиц и хранение в оперативной памяти в структурах, обеспечивающих максимальную скорость доступа.
- Поиск подходящих настроек в соответствии с переданным контекстом.
- Кэширование настроек между запусками программы. Сохранение в файле на локальном жестком диске при выходе. При запуске проверяется: менялись ли настройки в БД и если нет, то берутся из файла.
- Запись изменений, сделанных в течении сессии, в базу данных по команде или при завершении работы программы.
- Копирование настроек между пользователями системы или от пользователя системы в общие настройки.
- Оптимизация настроек -- удаление частных настроек, которые дублируют общие настройки.
Менеджер стилей работает на подобии технологии CSS. Например, запрашивается гарнитура шрифта для некоторой колонки грида:
- Сначала ищем указанный параметр по имени колонки, имени грида и имени типа формы (с учетом подтипа).
- Если не найден и грид подсоединен к БО, то ищем для бизнес-класса и имени поля.
- Если не найден, то ищем для таблицы и поля.
- Если не найден и для поля определен домен, то ищем для домена.
- Если не найден, то ищем для типа данных.
- Если не найден и определены общие параметры, то берем из них.
При этом, на каждом шаге ищем в следующем порядке:
- Для текущего пользователя.
- Если не найден, то для всех пользователей.
- Для текущей темы.
- Если нет, то общие (без темы).
Таблицы
Скрипты таблиц и сопутствующих триггеров располагаются в файле at_attribute.sql.
Конвертация
- Сделать парсер с помощью которого разобрать двоичные потоки настроек гридов и закинуть их в таблицы.
- Оптимизировать настройки, перенеся повторяющиеся значения на самый общий уровень.
- Старые потоки останутся в БД до того момента, когда мы сможем заменить все экзешники на предприятиях.
- При использовании нового экзешника старые потоки не будут грузится при загрузке Хранилища.
Диалоговое окно настройки грида
- Увеличить размер и перекомпоновать с учетом того, что экраны стали больше и нет необходимости разбивать на много вкладок.
- Запрос выкинуть (перенести) в окно Свойства объекта.
- Вкладку шаблоны выкинуть.
- Должно быть четко видно для какого пользователя мы настраиваем, для какой темы.
- Должно быть четко видно свойство установлено именно для этой колонки, этого грида, или его значение получилось по иерархии.
- Должна быть возможность как установить значение свойства, так и скинуть его -- тогда будет браться по иерархии.