أنواع الكائنات لإعداد السمة

نقدم نوعًا جديدًا type: objects إلى الأنواع المدعومة لإعدادات الثيمات والذي يمكن استخدامه لاستبدال النوع json_schema الحالي الذي نعتزم إيقافه قريبًا.

تعريف إعداد ثيم من نوع الكائنات (objects)

لإنشاء إعداد ثيم من نوع الكائنات، قم أولاً بتعريف مفتاح على المستوى الأعلى تمامًا مثل أي إعداد ثيم والذي سيُستخدم كاسم للإعداد.

links: ...

بعد ذلك، أضف الكلمات المفتاحية type و default و schema إلى الإعداد.

links:
  type: objects
  default: []
  schema: ...

يشير type: objects إلى أن هذا سيكون إعدادًا من نوع الكائنات بينما تحدد التعليقة default: [] القيمة الافتراضية للإعداد لتكون مصفوفة فارغة. لاحظ أنه يمكن أيضًا تعيين القيمة الافتراضية إلى مصفوفة من الكائنات والتي سنوضحها بمجرد تعريف schema.

لتحديد المخطط (schema)، قم أولاً بتعريف name للمخطط بهذه الطريقة:

links:
  type: objects
  default: []
  schema:
    name: link

بعد ذلك، سنضيف الكلمة المفتاحية properties إلى المخطط والتي ستسمح لنا بتعريف والتحقق من صحة شكل كل كائن.

links:
  type: objects
  default: []
  schema:
    name: link
    properties:
      name: ...

في المثال أعلاه، نذكر أن الكائن link يحتوي على خاصية name. لتحديد نوع البيانات المتوقع، يجب أن يحدد كل خاصية الكلمة المفتاحية type.

links:
  type: objects
  default: []
  schema:
    name: link
    properties:
      name:
        type: string

يحدد تعريف المخطط أعلاه أن الكائن link يحتوي على خاصية name من النوع string، مما يعني أنه سيتم قبول قيم السلسلة النصية فقط لهذه الخاصية. حاليًا، الأنواع التالية مدعومة:

  • string: يتم تخزين قيمة الخاصية كسلسلة نصية.
  • integer: يتم تخزين قيمة الخاصية كعدد صحيح.
  • float: يتم تخزين قيمة الخاصية كعدد عشري (float).
  • boolean: قيمة الخاصية هي true أو false.
  • uploads: قيمة الخاصية هي رابط المرفق
  • enum: يجب أن تكون قيمة الخاصية واحدة من القيم المحددة في الكلمة المفتاحية choices.
    links:
      type: objects
      default: []
      schema:
        name: link
        properties:
          name:
            type: enum
            choices:
              - name 1
              - name 2
              - name 3
    
  • categories: قيمة الخاصية هي مصفوفة من معرفات الفئات الصالحة.
  • groups: قيمة الخاصية هي مصفوفة من معرفات المجموعات الصالحة.
  • tags: قيمة الخاصية هي مصفوفة من أسماء العلامات الصالحة.

مع تعريف المخطط، يمكن الآن تعيين القيمة الافتراضية للإعداد عن طريق تعريف مصفوفة في YAML بهذه الطريقة:

links:
  type: objects
  default:
    - name: link 1
      title: link 1 title
    - name: link 2
      title: link 2 title
  schema:
    name: link
    properties:
      name:
        type: string
      title:
        type: string

الخصائص المطلوبة (Required properties)

جميع الخصائص المحددة اختيارية بشكل افتراضي. لوضع علامة على خاصية كـ “مطلوبة”، قم ببساطة بإضافة التعليق required: true إلى الخاصية. يمكن أيضًا وضع علامة على خاصية كـ “اختيارية” عن طريق إضافة التعليق required: false إلى الخاصية.

links:
  type: objects
  default: []
  schema:
    name: link
    properties:
      name:
        type: string
        required: true
      title:
        type: string
        required: false

عمليات التحقق المخصصة (Custom Validations)

بالنسبة لأنواع خصائص معينة، يوجد دعم مدمج لعمليات التحقق المخصصة والتي يمكن الإعلان عنها عن طريق إضافة التعليق validations إلى الخاصية.

links:
  type: objects
  default: []
  schema:
    name: link
    properties:
      name:
        type: string
        required: true
        validations:
          min: 1
          max: 2048
          url: true

عمليات التحقق لأنواع string

  • min_length: الحد الأدنى لطول الخاصية. يجب أن تكون قيمة الكلمة المفتاحية عددًا صحيحًا.
  • max_length: الحد الأقصى لطول الخاصية. يجب أن تكون قيمة الكلمة المفتاحية عددًا صحيحًا.
  • url: يتحقق من أن الخاصية هي عنوان URL صالح. يمكن أن تكون قيمة الكلمة المفتاحية true/false.

عمليات التحقق لأنواع integer و float

  • min: الحد الأدنى لقيمة الخاصية. يجب أن تكون قيمة الكلمة المفتاحية عددًا صحيحًا.
  • max: الحد الأقصى لقيمة الخاصية. يجب أن تكون قيمة الكلمة المفتاحية عددًا صحيحًا.

عمليات التحقق لأنواع tags و groups و categories

  • min: الحد الأدنى لعدد السجلات للخاصية. يجب أن تكون قيمة الكلمة المفتاحية عددًا صحيحًا.
  • max: الحد الأقصى لعدد السجلات للخاصية. يجب أن تكون قيمة الكلمة المفتاحية عددًا صحيحًا.

هيكل الكائنات المتداخلة (Nested objects structure)

يمكن أن يحتوي الكائن أيضًا على خاصية تحتوي على مصفوفة من الكائنات. لإنشاء هيكل كائنات متداخل، يمكن أيضًا إضافة تعليق type: objects إلى خاصية مع تعريف المخطط schema المرتبط بها.

sections:
  type: objects
  default:
    - name: section 1
      links:
        - name: link 1
          url: /some/url
        - name: link 2
          url: /some/other/url
  schema:
    name: section
    properties:
      name:
        type: string
        required: true
      links:
        type: objects
        schema:
          name: link
          properties:
            name:
              type: string
            url:
              type: string

وصف الإعداد والتعريب (Localization)

لإضافة وصف للإعداد في اللغة المحلية en، قم بإنشاء ملف locales/en.yml بالتنسيق التالي نظرًا لوجود إعداد ثيم من نوع الكائنات.

sections:
  type: objects
  default:
    - name: section 1
      links:
        - name: link 1
          url: /some/url
        - name: link 2
          url: /some/other/url
  schema:
    name: section
    properties:
      name:
        type: string
        required: true
      links:
        type: objects
        schema:
          name: link
          properties:
            name:
              type: string
            url:
              type: string
en:
  theme_metadata:
    settings:
      sections:
        description: This is a description for the sections theme setting
        schema:
          properties:
            name:
              label: Name
              description: The description for the property
            links:
              name:
                label: Name
                description: The description for the property
              url:
                label: URL
                description: The description for the property

يتم التحكم في إصدار هذه الوثيقة - اقترح تغييرات على github.

16 إعجابًا

ما زلت غير مقتنع بأن إلغاء نمط مخطط JSON فكرة جيدة.

في حين أن هذه يمكن أن تصبح معقدة للغاية وليست الأكثر “ودية للمطورين” من التنسيقات (لذا هذا تغيير رائع في هذا الصدد)، هناك أدوات عبر الإنترنت للتحقق من صحة مخططات JSON وهو أمر مفيد حقًا للتحقق من كل من المخطط وضد أي بيانات افتراضية.

على سبيل المثال: https://www.jsonschemavalidator.net/

كيف سيعمل ذلك في هذا العالم الجديد؟

إعجابَين (2)

عند تحميل سمة، سنتحقق من صحة البيانات الافتراضية مقابل المخطط المحدد. ومع ذلك، نحن لا نتحقق من صحة تعريف المخطط الآن، ولكن لن يكون من الصعب علينا القيام بذلك. حتى بالنسبة لإعداد المخطط json حاليًا، لا أعتقد أننا نتحقق من صحة البيانات الافتراضية مقابل المخطط المحدد.

إن تطبيقنا الحالي لإعدادات نوع المخطط json معطل بطرق عديدة، وأوضحها هو المحرر في الواجهة الإدارية. ناقشنا هذا داخليًا وقررنا أنه من الأسهل بكثير بالنسبة لنا الحفاظ على تنسيق مخطط محدود نحدده بأنفسنا بدلاً من السماح بجميع الاحتمالات التي تأتي مع مخطط json.

إعجابَين (2)

بعض الميزات الرائعة هنا:

  • يمكنك التخلص من JSON.parse والوصول مباشرة إلى الإعداد للحصول على الكائن وهو أمر رائع حقًا.

  • مدقق الروابط!

:chefs_kiss: :chefs_kiss:

5 إعجابات

هل هناك أي طريقة لاحترام الأسطر المتعددة في المحرر؟

هذا الافتراضي يعمل:

- name: markdown
  value: > 
    ## Heading
      * first bullet
      * second bullet

ولكن بمجرد تعديل هذا، يتم فقدان عودات العربة

علاوة على ذلك، سيكون من الجيد وجود نوع "نص" يمكنه تخزين بيانات أطول وربما يعرض محرر "مساحة نصية" أكبر

5 إعجابات

إليك بعض الملاحظات:

إعجابَين (2)

لاحظت هذا وقد تم إصلاحه في

إعجاب واحد (1)

هل سنتمكن من إعادة ترتيب العناصر في الواجهة؟

على سبيل المثال، هذا هو محرر إعدادات الكائن في مكون سمة التذييل السهل. لا يمكنني إعادة ترتيب أي عناصر في الوقت الحالي:

4 إعجابات

أردت طلب هذه الميزة أيضًا! :+1:


على صعيد آخر، سيكون من المفيد لو احتوى المنشور الأول على معلومات حول خاصية identifier.

قبل النظر إلى صورة Nolo أعلاه، اعتقدت أنه من المستحيل استبدال تسمية الطفل الافتراضية بقيمة خاصية. بعد النظر إلى الكود، وجدت خاصية identifier.

4 إعجابات

إعادة الترتيب هو بالتأكيد شيء تم طرحه داخليًا أيضًا. سأحاول إنجازه هذا الأسبوع.

تم الإحاطة علماً. سأقوم بتحديث المنشور الأول بشأن خاصية identifier.

5 إعجابات

نعم، لاستبدال النظام القديم (الذي سيصبح قريباً قديماً؟) بصيغة JSON، يجب أن يطابق الواجهة القديمة أو يتجاوزها:

بما في ذلك الترتيب.

إعجاب واحد (1)

مرحباً، هل هناك أي خطط لدعم أنواع حقول أخرى قريباً؟

على سبيل المثال؛

  • long_string بتنسيق markdown؛ ربما مع شريط أدوات قابل للتخصيص،
  • حقل date (مع قواعد التحقق)،
  • حقل color (مع قواعد التحقق)؟
إعجاب واحد (1)

لا توجد خطة حالية، على الرغم من أنني أتفق على أنه سيكون مفيدًا. أود حقل icon بنفسي.

7 إعجابات

في تجربتي، يبدو أن هذا يعمل مثل الإعدادات المسبقة المحفوظة. في هذا المثال، يمكن أن تستفيد الإدخالات الأولى 2 من هذه الإعدادات المسبقة، ولكن أي شيء بعد ذلك ستظهر جميع الإدخالات الجديدة فارغة في البداية.

هذا يعني أيضًا أنه لا يمكننا تعيين قيم افتراضية لكل حقل. على سبيل المثال، إذا كنت أرغب في الحصول على مربع اختيار، ليبدأ في حالة محددة، فلا يمكنني الحصول عليه.

links:
  type: objects
  default:
    - name: link 1
      title: link 1 title
    - name: link 2
      title: link 2 title
  schema:
    name: link
    properties:
      is_active:
        type: boolean
        default: true

لن يعمل default: true هناك كما هو متوقع.

هل يمكن أن تكون هناك طريقة لتعيين القيم الافتراضية لكل حقل، لكل الإدخالات التي تم إنشاؤها؟

هل هناك طريقة لاستيراد خصائص الكائنات إلى متغيرات في Sass؟

يمكنك دائمًا تحليل السلسلة النصية، لكن لا يبدو أن هذه فكرة رائعة للترويج لها بهذه الطريقة. :sweat_smile:

إعجاب واحد (1)

شكراً لمشاركة المثال! على الرغم من ذلك، نعم.. لا يبدو ذلك مغرياً :upside_down_face:

إعجاب واحد (1)

من باب الفضول، دون قضاء الكثير من الوقت في البحث، ما هو وضعنا مع هذا؟

إعجابَين (2)

نعم، إنه ليس جيدًا جدًا، لا تفعل ذلك. :). لقد كان محاولة لمعرفة ما إذا كان ذلك ممكنًا، ولكن ليس نهجًا معقولًا.
أتفق معك؛ سيكون من الرائع وجود طريقة مباشرة! :+1:

أود أن أعرف، أيضًا!
أيضًا، إذا كنت على حق، فستكون هذه هي الميزة الوحيدة المفقودة مع json_schema.

إعجابَين (2)

كنت أبحث عن نوع التحميل ليكون متاحًا، ولكنه غير موجود.
نظرة سريعة على النواة تظهر أنه تم تنفيذ أنواع الموضوع والمنشور والتحميل من جانب الخادم ولكن ليس في الواجهة الأمامية. هل هناك سبب محدد لذلك؟ :thinking: