Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.

...

Inside new fee structure, we will create the methods that will used to form fields.
  • path: intl-whitelabel-cms/schemas/fees/objects/fee-fields.tsx

  • We will need of the fields to:

    • Toggle;

    • Title;

    • text;

    • Combo-box;

    • Period date (start date and end date);

    • Restaurant group;

    • Fee config group;

  • Extra method:

    • Format date method;

  • See: https://github.com/rbilabs/intl-whitelabel-cms/tree/poc/IBFEC-1747-fees-custom-message-3

  • Create the
    Expand
    titleTASK 2 - Create a method to base the fields
    the
    Expand
    titleTASK 3 - Create the Fee Config
    Fee config form
    • Create the fee config fields

      • path: intl-whitelabel-cms/schemas/fees/documents/fee-config.tsx

      • path: intl-whitelabel-cms/schemas/fees/documents/fee-config-list.tsx

      • Using the method bases create;

    Expand
    titleTASK 4 3 - Create the Fee Restaurant Configconfig form
    Expand
    titleTASK 5 4 - Disable the fields after first publish
    • After the first publish we will need to disable the fields:

      • Default Config

      • Fee Type

    As the Fee Config document is used in the Fee Restaurant Config document the user can change the toggle even if the document is already published. As we don’t find a way to control this we need to ensure that the user will not be able to change the value of the toggle after the first publish.

    Sanity doc:

    https://dev-plk-es-whitelabel-cms.rbi.tools/desk/marketingContent;features;featureFee;feesConfig

    image-20240429-175740.png

    To achieve that, we can:

    1. Create a custom publish action (https://www.sanity.io/docs/document-actions)

      1. This action will be responsible for setting true on the new custom field isPublished (see below for more details) - https://www.sanity.io/docs/document-actions#362c883e4421 and https://www.sanity.io/docs/http-patches#6TPENSW3

    2. Condition this new action to be only available for the Fee Config document (without affecting the other documents)

    3. Create a new custom field in the Fee Config option to know if the document is already published or not (the name can be isPublished, for example)

      1. Add the hidden to this new field, as the user doesn’t need to see it. This field will only be used to control if the toggle is read-only or not (aka disabled)

    4. Add the readOnly property to the Default Config toggle using the new isPublished prop

    5. See: https://github.com/rbilabs/intl-whitelabel-cms/tree/poc/IBFEC-1747-fees-custom-message-3

    Demonstration

    Default Config toggle read only after first publish.webm

    ...

    Expand
    titleTASK 1 - [intl-whitelabel-cmsapp] - Create Feature Fee page on sanitya new query to get the Sanity values
  • Create a new Fragment and change the RestaurantGroup queries

    image-20240415-092445.pngImage Removed

  • Run apollo generate to create the sanity graphql method
    Expand
    titleTASK 2 1 - [intl-whitelabel-app] - Create hook to get the sanity infos
    • Create a hook to get the Fee values

    • We can use the: frontend/src/hooks/use-restaurant-groups/use-restaurant-groups.ts

    • Or we can create a new hook using the useResturantGroupByGroupIdQuery query also used in the hook above

      config values;

    Create a feature flag to use the new fields or validation (if using the existing hook);
    Expand
    titleTASK 3 - [intl-whitelabel-app] - Create a method to validate the fee values
    config values
    Expand
    titleTASK 4 - [intl-whitelabel-app] - Add the promotion description on table fee modal
    • Add the Fee discount message on the table fee modal

      • The message needs to use the method created to validate he the fee values

    Screenshots

    N/A

    Unit Test

    ...