CMS Configuration
Nanc has powerful in-depth customization capabilities for many aspects of the view and behavior. The current version of the available settings for customization is shown below:
import 'dart:async';
import 'package:flutter/material.dart';
import 'package:nanc/nanc.dart';
import 'package:nanc/services.dart';
import 'package:nanc_configuration/nanc_configuration.dart';
Future<void> main() async {
  await runZonedGuarded(() async {
    WidgetsFlutterBinding.ensureInitialized();
    await adminRunner(
      CmsConfig(
        collectionApi: ICollectionApi(),
        documentApi: IDocumentApi(),
        modelApi: IModelApi(),
        networkConfig: NetworkConfig(
          paginationPageNumberParameterName: 'page',
          paginationLimitParameterName: 'limit',
          paginationDataContainerParameterName: 'data',
          paginationTotalPagesParameterName: 'total',
          paginationLimitParameterDefaultValue: 20,
        ),
        imageBuilderDelegate: null,
        adminWrapperBuilder: null,
        predefinedModels: [],
        customRenderers: [],
        eventsHandlers: [],
        customFonts: [],
        sliverChecker: null,
        customIcons: null,
        themeBuilder: null,
      ),
    );
  }, ErrorsCatcher.catchZoneErrors);
}
Let's go through them one by one.
Collection API
This option is responsible for setting up an API service that will perform all network activities related to your document collections. Be it filtering, pagination, search, and more.
Document API
The documentApi is responsible for implementation of API service that will perform network requests related to individual documents - opening a detailed document page, creating, deleting, modifying, etc.
Model API
The modelApi allows you to set up an API service that will be responsible for network requests related to the model. If you decide to change the very data structure of your documents - you will be changing the model. And all changes made to the model structure can be mirrored in your infrastructure. For example - when creating a new model, you may want to automatically create a corresponding table in your database. This service will be responsible for that logic.
However, some data providers do not require the explicit creation of tables or their counterparts, such as - Firebase. In this case, the implementation of this service can be empty, because you do not need additional actions to get a new data structure (a new document, in this case).
Network config
This option allows you to set basic network settings:
Page number name
paginationPageNumberParameterName may be useful when you are implementing your own ICollectionApi service. Like all network parameters, to be honest. Going back to this particular parameter - you can use it to set the name of the expected key of the response returned by the server with the collection of documents, which will contain information about the current page of the received data.
Pagination limits name
paginationLimitParameterName - this option, in turn, will be sent as one of the parameters to your backend, to get a portion of the documents (part of the collection) with a certain amount (limit) in it.
Pagination data name
paginationDataContainerParameterName the expected name of the field containing the document array in the response from your server when trying to retrieve a collection of documents.
Total pages name
paginationTotalPagesParameterName expected name of the field containing the total number of pages with documents in the requested collection.
Default pagination limits
paginationLimitParameterDefaultValue the default value that determines how many documents will be requested per collection page.
Example of collection response with the default fields names
{
  "page": 1,
  "total_pages": 23,
  "data": [
    {
      "id": "f2fe31b0-f473-4108-b7b6-935545a34fad",
      "some_field": 123,
      "some_another_field": "abc"
    },
    // ... 99 elements here
  ]
}
Image builder delegate
The imageBuilderDelegate gives you the ability to customize the rendering behavior of the images you can display with the Nanc Server driven UI. You can implement your own preloader, show BlurHash or do whatever you see fit.
Admin wrapper builder
The adminWrapperBuilder is a special builder-method that allows you to wrap the CMS into your own widget or even an entire application. For example, you can use this functionality to implement additional authorization by showing the user of your Nanc CMS a modal window, asking for credentials to access the CMS. Or you can extend Nanc's functionality as much as you want.
In the future, extensibility will become even more advanced, allowing you to replace any parts of the CMS, fully customizing it to your needs.
Predefined models
predefinedModels is a set of code-first models that will be available in your Nanc CMS immediately. You can also add here source code of those models that are created in Nanc through the interface. In this case, this model will become a hybrid model. What this is, is described in detail in the section about Models.
Custom renderers
customRenderers - a setting responsible for extending the Nanc functionality related to rendering widgets in the Server driven UI. By implementing and adding a new renderer you will be able to use it at any time in your application using Nanc Server Driven UI. You can learn more about this in this section: Server driven UI.
Events handlers
eventsHandlers - parameter responsible for extending the logic that you will be able to control through the Nanc Server Driven UI.
The current model is event-based. An event is a string that can contain anything. From a simple name, to a JSON structure, a link, or anything. The EventHandler is responsible for handling a certain class of events, for example - all events starting with the keyword deeplink. Or all events that contain a value corresponding to some RegExp pattern. How exactly the event handling will be implemented is entirely your responsibility, and your opportunity.
By intelligently separating the possible events in your application into classes, you can reach a state where you can modify and create very complex user scenarios, and all this will be available to your users in real time. Read more about this in the Server Driven UI section.
Also, you may want to consider just specifying an identifier as the event, the corresponding handler will take that identifier, go to the backend, and get all the necessary arguments from that identifier that you would otherwise have to specify in the event itself.
Custom fonts
customFonts - an option to expand the available fonts in the Nanc Server Driven UI. You can add any custom font to your Nanc CMS, then, specify the parameters of the added font in this configuration, which accepts a list of font extensions, and voila - in your Nanc CMS, your newly added font will appear in the FontField field, which you will be able to use in the app as well, relying on the Nanc Server Driven UI.
Sliver checker
If you are going to add custom sliver widgets implemented by you. You also need to add a function that will check if the widget is a sliver. And for your custom sliver - it should return true. See more about slivers here.
Custom icons
You can easily add your own custom icons to Nanc. For this purpose it is enough to pass Map<String, IconData> as an argument to customIcons. Configuring a mobile application using Nui is described in detail here.
Preview theming
In order to be able to recreate your mobile app design in Nanc using Nui, you can use the theme with themeBuilder from your mobile app. This way you will see in Nui pixel-perfect preview the same result to what you will see in your mobile application when developing components / screens using Nui.
Web app configuration
For the Nanc-IDE synchronization functionality to work correctly in a web environment, you need to add the following line to the path_to_your_nanc_cms_project/web/index.html file:
   <!-- This script adds the flutter initialization JS code -->
   <script src="flutter.js" defer></script>
    <!-- ⬇︎⬇︎ ADD THIS LINE HERE ⬇︎⬇︎ -->
   <script src="file_system_library.js" defer></script>
</head>
And copy the corresponding file nanc/file_system_library.js to the same path: path_to_your_nanc_project/web/file_system_library.js
You can learn more about synchronization with the IDE in the Server Driven UI section.
Mobile app configuration
If you are planning to use Nanc Server Driven UI in a mobile Flutter application, it is necessary to configure it as well. To do this, pay attention to the following section: Mobile App Configuration section.