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

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

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

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

links: ...

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

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

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

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

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

بعد ذلك، سنضيف الكلمة المفتاحية properties إلى المخطط (schema) والتي ستسمح لنا بتعريف والتحقق من كيفية ظهور كل كائن.

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

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

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

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

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

مع تعريف المخطط (schema)، يمكن الآن تعيين القيمة الافتراضية للإعداد عن طريق تحديد مصفوفة في 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: true. يمكن أيضًا تمييز الخاصية على أنها اختيارية عن طريق تعليق الخاصية بـ required: false.

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

التحقق المخصص

بالنسبة لأنواع خصائص معينة، يوجد دعم مدمج للتحقق المخصص الذي يمكن الإعلان عنه عن طريق تعليق الخاصية بالكلمة المفتاحية 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)

يمكن للكائن (object) أيضًا أن يحتوي على خاصية تحتوي على مصفوفة من الكائنات (objects). لإنشاء هيكل كائنات متداخلة، يمكن أيضًا تعليق خاصية بـ 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

وصف الإعداد والترجمة المحلية

لإضافة وصف للإعداد في اللغة المحلية en، قم بإنشاء ملف locales/en.yml بالتنسيق التالي مع إعداد السمة من نوع الكائنات (objects) التالي.

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

This document is version controlled - suggest changes on github.

15 إعجابًا

ما زلت غير مقتنع بأن إلغاء نمط مخطط 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.

4 إعجابات

نعم، لاستبدال النظام القديم (الذي سيصبح قريباً قديماً؟) بصيغة 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: