Тип объектов для настройки темы

Да, я имею в виду ограничение максимального количества элементов в массиве objects.

На данный момент официальная версия не поддерживает эту функцию, поэтому я расширил её в кастомном приватном компоненте темы. Ниже приведена конфигурация (для справки):

Конфигурация ограничения максимального количества элементов массива:

themes/quectel-custom-homepage/settings.yml

banner_images:
  type: objects
  default: []
  schema:
    name: "Слайдер"
    max: 9 // Новое расширенное свойство, ограничивающее максимальное количество элементов массива
    identifier: image_url
    properties:
      image_url:
        type: upload
        required: true
      link_url:
        type: string
        min: 0
        max: 1023

Детали реализации расширения:

themes/quectel-custom-homepage/javascripts/discourse/api-initializers/quectel-custom-homepage.gjs

import { action } from "@ember/object";
import { apiInitializer } from "discourse/lib/api";
import classPrepend from "discourse/lib/class-prepend";
import { i18n } from "discourse-i18n";

export default apiInitializer(() => {
  // Расширяем компонент SchemaSettingNewEditor с помощью classPrepend для поддержки ограничения max для типа objects
  // Загружаем этот компонент только в контексте администратора
  let SchemaSettingNewEditor;
  try {
    SchemaSettingNewEditor =
      require("discourse/admin/components/schema-setting/editor").default;
  } catch {
    // Пользователи без прав администратора не могут загрузить этот компонент, пропускаем расширение
    return;
  }

  classPrepend(SchemaSettingNewEditor, (Superclass) => {
    return class extends Superclass {
      @action
      addItem() {
        // Проверяем, достигнуто ли ограничение max
        const maxLimit = this.args.setting.max || this.activeSchema?.max;

        if (maxLimit && this.activeData.length >= maxLimit) {
          this.validationErrorMessage = i18n(
            themePrefix("theme_settings.errors.objects_value_not_valid_max"),
            {
              count: maxLimit,
            }
          );
          return;
        }

        return super.addItem(...arguments);
      }

      @action
      addChildItem(propertyName, parentNodeIndex) {
        const propertySchema = this.activeSchema.properties[propertyName];

        // Проверяем, достигнуто ли ограничение max
        if (
          propertySchema?.max &&
          this.activeData[parentNodeIndex][propertyName].length >=
            propertySchema.max
        ) {
          this.validationErrorMessage = i18n(
            themePrefix("theme_settings.errors.objects_value_not_valid_max"),
            {
              count: propertySchema.max,
            }
          );
          return;
        }

        return super.addChildItem(...arguments);
      }
    };
  });
});

Конфигурация перевода темы:

themes/quectel-custom-homepage/locales/zh_CN.yml

zh_CN:
  theme_settings:
    errors:
      objects_value_not_valid_max: "Количество не может превышать %{count}"

Результат:

  1. Сообщение об ошибке
  2. Невозможно добавить больше элементов
1 лайк