Сохранение параметров грида

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

Версия 01:12, 22 февраля 2016

Разрабатывается система для работы со всеми визуальными настройками платформы, но, в первую очередь, для работы с визуальными настройками гридов.

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

Ядром системы будет объект TgdStyleManager, который отвечает за следующие функции:

  • Считывание настроек из реляционных таблиц и хранение в оперативной памяти в структурах, обеспечивающих максимальную скорость доступа.
  • Поиск подходящих настроек в соответствии с переданным контекстом.
  • Кэширование настроек между запусками программы. Сохранение в файле на локальном жестком диске при выходе. При запуске проверяется: менялись ли настройки в БД и если нет, то берутся из файла.
  • Запись изменений, сделанных в течении сессии, в базу данных по команде или при завершении работы программы.
  • Копирование настроек между пользователями системы или от пользователя системы в общие настройки.
  • Оптимизация настроек -- удаление частных настроек, которые дублируют общие настройки.

Менеджер стилей работает на подобии технологии CSS. Например, запрашивается гарнитура шрифта для некоторой колонки грида:

  1. Сначала ищем указанный параметр по имени колонки, имени грида и имени типа формы (с учетом подтипа).
  2. Если не найден и грид подсоединен к БО, то ищем для бизнес-класса и имени поля.
  3. Если не найден, то ищем для таблицы и поля.
  4. Если не найден и для поля определен домен, то ищем для домена.
  5. Если не найден, то ищем для типа данных.
  6. Если не найден и определены общие параметры, то берем из них.

При этом, на каждом шаге ищем в следующем порядке:

  1. Для текущего пользователя.
  2. Если не найден, то для всех пользователей.
  3. Для текущей темы.
  4. Если нет, то общие (без темы).

Таблицы

Скрипты таблиц и сопутствующих триггеров располагаются в файле at_attribute.sql.

Конвертация

  1. Сделать парсер с помощью которого разобрать двоичные потоки настроек гридов и закинуть их в таблицы.
  2. Оптимизировать настройки, перенеся повторяющиеся значения на самый общий уровень.
  3. Старые потоки останутся в БД до того момента, когда мы сможем заменить все экзешники на предприятиях.
  4. При использовании нового экзешника старые потоки не будут грузится при загрузке Хранилища.

Диалоговое окно настройки грида

  1. Увеличить размер и перекомпоновать с учетом того, что экраны стали больше и нет необходимости разбивать на много вкладок.
  2. Запрос выкинуть (перенести) в окно Свойства объекта.
  3. Вкладку шаблоны выкинуть.
  4. Должно быть четко видно для какого пользователя мы настраиваем, для какой темы.
  5. Должно быть четко видно свойство установлено именно для этой колонки, этого грида, или его значение получилось по иерархии.
  6. Должна быть возможность как установить значение свойства, так и скинуть его -- тогда будет браться по иерархии.
Персональные инструменты
Пространства имён

Варианты
Действия
Навигация
Инструменты