Skip to content

Commit 42e437c

Browse files
authored
Merge branch 'main' into feature/update-adding-design-system
2 parents 195eed5 + 1471c42 commit 42e437c

File tree

14 files changed

+350
-89
lines changed

14 files changed

+350
-89
lines changed

docs/accounts-billing/payments-billing.md

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -5,7 +5,7 @@ This section contains information on the payment methods we accept and how to ch
55

66
## Invoices
77
#### Can I Add A Tax ID (e.g. VAT) to my invoice?
8-
Unfortunately, at this time we are not able to process Tax IDs.
8+
If you need to include VAT in your invoices, please reach out to our support team at [email protected], and we’ll be happy to assist you with the process.
99

1010

1111
## Payment Methods
Binary file not shown.

docs/ff-concepts/navigation-routing/share-action.md

Lines changed: 4 additions & 48 deletions
Original file line numberDiff line numberDiff line change
@@ -9,54 +9,10 @@ keywords: [FlutterFlow, Share Action, Navigation, Concepts]
99

1010
# Share [Action]
1111

12-
Share Action can be used to send a text using the Android or iOS device's share dialog. You can send the text using email, message, or any other application present on the device that supports sharing functionality.
13-
14-
<figure>
15-
<img src="https://firebasestorage.googleapis.com/v0/b/ecommerceflow-docs/o/share-example.gif?alt=media&token=f902c889-56e0-4f40-9413-7e5852d5d8c2"></img>
16-
<figcaption class="centered-caption"></figcaption>
17-
</figure>
18-
19-
## Define Share Action
20-
21-
Go to your project page on FlutterFlow and follow the steps below to define an Upload Photo/Video Action to a widget:
22-
23-
1. Select the **widget** in which you want to set the Action.
24-
25-
2. Select the **Actions** from the Properties Panel (the right menu).
26-
27-
3. Click **+ Add Action** button.
28-
29-
4. Choose a gesture from the dropdown among ***On Tap****,* ***On Double Tap****,**or* **On Long
30-
Press**.
31-
32-
5. Select the **Action Type** as ***Share***.
33-
34-
6. Now, you need to specify a **URL/Text Value**. It can be set either by defining a **Specific
35-
Value** or by using **From Variable** to use a value stored inside a variable.
36-
- If you are using **Specific Value**, enter the text in the **Value** field.
37-
- If you are using **From Variable**, you need to select the **Source**.
38-
39-
Demo of defining Share Action using a **Specific Value** is as follows:
40-
41-
<img src="https://firebasestorage.googleapis.com/v0/b/ecommerceflow-docs/o/share-with-value.gif?alt=media&token=415cf039-dae7-4ee0-ad3c-c31a8c5c4a50"></img>
42-
43-
<p></p>
44-
45-
Alternatively, a demo of defining Share Action using **From Variable** option is as follows:
46-
47-
<p></p>
48-
49-
50-
<figure>
51-
<img src="https://firebasestorage.googleapis.com/v0/b/ecommerceflow-docs/o/share-with-variable.gif?alt=media&token=7d77df34-7c82-47fe-ba50-8eedf699c6ea"></img>
52-
<figcaption class="centered-caption"></figcaption>
53-
</figure>
54-
12+
The **Share Action** enables users to send text or URLs from your app using the native sharing capabilities of their device. This functionality allows users to share information through various applications installed on their devices, such as email, messaging apps, or social media platforms.
5513

5614
:::warning
57-
You won't be able to try out this Action using FlutterFlow's *Run Mode* or *Preview Mode*. To
58-
test this Action, you have to run it on an iOS or Android device or emulator. You can either
59-
**Download the Code** (by going to `Developer Menu > Download Code`) and build it for your
60-
device, or use the **Build APK** button (present on the [**Tool Bar**](../../intro/ff-ui/toolbar.md) to generate an APK that
61-
you can run on your Android device.
15+
It's important to note that the Share Action is designed for mobile platforms and is not supported in FlutterFlow's Run Mode or Preview Mode. To test this functionality, you need to [**run your app on an iOS or Android device or emulator**](../../testing-deployment-publishing/running-your-app/local-run.md).
6216
:::
17+
18+
![share-action](imgs/share-action.avif)

docs/marketplace/creators-hub/submission-criteria.md

Lines changed: 25 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -203,10 +203,30 @@ A seamless and positive test experience is crucial for users to evaluate your Fl
203203

204204
#### 4.1 Functional Run Mode Link
205205

206-
- **Criteria:** The provided Run Mode link must be active and correctly load a working demo of your project.
207-
- **Why it Matters:** The Run Mode link is the primary way users can interact with your project before purchasing. A broken or inaccessible link creates a significant barrier.
208-
- **What To Do:**
209-
- **Double-check your link:** Before submitting, test the link multiple times to confirm it showcases the experience you want potential buyers to have.
206+
- **Criteria:** The provided Run Mode link must be active and correctly load a working demo of your project. For mobile-only features or utility libraries that cannot be demonstrated in Run Mode's web environment, you must provide alternative demonstration methods.
207+
- **Why it Matters:** The Run Mode link is the primary way users can interact with your project before purchasing. A broken, inaccessible, or non-demonstrative link creates a significant barrier to understanding the item's value.
208+
- **What To Do:**
209+
- **For Standard Web-Compatible Items:**
210+
- Double-check your link before submitting to confirm it showcases the experience you want potential buyers to have.
211+
- Test the link multiple times to ensure consistent functionality.
212+
- **For Mobile-Only Features:**
213+
- Create a dedicated demonstration page in your project that explains the mobile-only functionality.
214+
- Include screenshots, videos, or mockups showing how the feature works on mobile devices.
215+
- Clearly indicate which features are mobile-only and why they cannot be demonstrated in Run Mode.
216+
- Optionally, provide a published FlutterFlow web deploy link that can be used instead of the Run Mode URL.
217+
- **For Utility Libraries (e.g., Analytics, Background Services):**
218+
- Create a demonstration page that explains the library's functionality.
219+
- Show configuration options and expected outcomes.
220+
- Include visual aids like flowcharts or diagrams to explain the library's operation.
221+
- Provide example code or configuration snippets.
222+
- Consider adding debug/test outputs that demonstrate the library is working.
223+
- **Documentation:**
224+
- Regardless of the type of item, ensure your documentation clearly explains how to implement and test the functionality in a real mobile environment.
225+
- Include troubleshooting guides and common implementation scenarios.
226+
227+
:::tip
228+
For items that cannot be fully demonstrated in Run Mode, focus on creating a clear, informative demonstration page that helps users understand the value and implementation of your item. Visual aids, clear explanations, and comprehensive documentation are key to helping users make informed decisions.
229+
:::
210230

211231
#### 4.2 User Sign-In (Anonymous Auth)
212232

@@ -251,7 +271,7 @@ Building a solid app template goes beyond surface-level design. It's about creat
251271
#### 5.2 No Pixel Overflow
252272

253273
- **Criteria:** Ensure your UI elements are positioned and sized correctly to avoid content overflowing its container, leading to visual glitches / cut off content.
254-
- **Why It Matters:** Pixel overflows are a sign of UI inconsistencies that can negatively impact the user experience, especially on different screen sizes. Pixel overflow issues can occur in Test Mode when theres a hardcoded pixel value and not enough space on the screen to render that exact value.
274+
- **Why It Matters:** Pixel overflows are a sign of UI inconsistencies that can negatively impact the user experience, especially on different screen sizes. Pixel overflow issues can occur in Test Mode when there's a hardcoded pixel value and not enough space on the screen to render that exact value.
255275
- **What To Do:**
256276
- **Preview pixel overflows:** Toggle the pixel overflow icon in the top-right of the canvas to see if there are any overflow issues.
257277
- **Leverage FlutterFlow's layout tools:** Use Expanded and Flex values to help prevent layout issues. Make `Columns` or `Rows` scrollable to prevent overflows. Use auto-sizing text or text clipping where it makes sense. Remove hard-coded width and height where it makes sense.

docs/resources/control-flow/backend-logic/api/rest-api.md

Lines changed: 75 additions & 23 deletions
Original file line numberDiff line numberDiff line change
@@ -569,38 +569,70 @@ Learn more about **[JSONPath](https://www.rfc-editor.org/rfc/rfc9535.html)** and
569569
:::
570570

571571
### Adding JSON Path
572+
You can effortlessly define and manage **JSON Paths** for your API calls in FlutterFlow to parse and extract the data you need. Once added you can [use](#using-json-path) them as **Predefined Path** while accessing the **JSON Body**.
572573

573-
To add JSON path:
574+
First, [create and test](../api/create-test-api-calls.md) your API call. Inside the **JSON Paths** section, click **+ Add JSON Path**, enter your **JSON Path**, and assign it a name. If the expression is valid, a preview of the response appears under **Response Preview**. Click the **Preview** icon to see the full response. If the response contains a list of items, the **Is List** option will be enabled automatically.
574575

575-
1. First, [create and test](../api/create-test-api-calls.md) your API call.
576-
577-
2. Inside the **JSON Paths** section, click on the **+ Add JSON Path**.
578-
3. Enter your **JSON Path** and give it a **Name**.
579-
4. If you entered the valid expression, you'll see the starting part of the response under the **Response Preview** column. To see the complete response, click on the **Preview** icon.
580-
5. If the returned response is a list of items, by default, **Is List** will be checked; however, if you want to convert the response into the list explicitly, checkmark it.
581-
6. We also recommend all the possible JSON paths (under the **Recommended** tab) that might include what you are looking for.
582-
583-
1. To add the recommended JSON path, checkmark the **Selected**, open the **Selected** tab,
584-
and give it a name.
585-
586-
<div class="video-container"><iframe src="https://www.loom.
587-
com/embed/fb4f0f0cbdc64ecface05622a8b8cc37?sid=e82499c7-b581-4d62-a197-037ee31a14b0" frameborder="0" allow="accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture; web-share" referrerpolicy="strict-origin-when-cross-origin" allowfullscreen></iframe></div>
576+
Under the **Recommended** section, you'll find suggested JSON paths that might contain the data you need.
588577

578+
<div style={{
579+
position: 'relative',
580+
paddingBottom: 'calc(56.67989417989418% + 41px)', // Keeps the aspect ratio and additional padding
581+
height: 0,
582+
width: '100%'}}>
583+
<iframe
584+
src="https://demo.arcade.software/mJBbGANYmn6SrtrByAYf?embed&show_copy_link=true"
585+
title=""
586+
style={{
587+
position: 'absolute',
588+
top: 0,
589+
left: 0,
590+
width: '100%',
591+
height: '100%',
592+
colorScheme: 'light'
593+
}}
594+
frameborder="0"
595+
loading="lazy"
596+
webkitAllowFullScreen
597+
mozAllowFullScreen
598+
allowFullScreen
599+
allow="clipboard-write">
600+
</iframe>
601+
</div>
602+
<p></p>
589603

590604

591605
### Using JSON Path
592606

593-
While accessing values from an API Call, you can either enter the custom JSON path or use the already created JSON path.
594-
595-
To use the already added JSON path:
607+
While accessing values from an API Call, you can either enter the custom JSON path or use the [predefined JSON path](#adding-json-path).
596608

597-
1. Select your API response.
598-
2. Set the **API response Options** to **JSON Body**.
599-
3. Set the **Available Options** to **JSON Path**.
600-
4. Set the **JSON Path Name** to the one that you created earlier.
609+
To use a predefined JSON Path, first, select your API response. Then, set the **API Response Options** to **JSON Body** and the **Available Options** to **JSON Path** or **Predefined Path**. Finally, specify the JSON Path Name or select from the predefined JSON Path to map the extracted data for use in your app.
601610

602-
<div class="video-container"><iframe src="https://www.loom.
603-
com/embed/502ffe547e64486c937e74c02b28fd3a?sid=21233fb9-9782-4e2f-b04a-a888d784f62f" frameborder="0" allow="accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture; web-share" referrerpolicy="strict-origin-when-cross-origin" allowfullscreen></iframe></div>
611+
<div style={{
612+
position: 'relative',
613+
paddingBottom: 'calc(56.67989417989418% + 41px)', // Keeps the aspect ratio and additional padding
614+
height: 0,
615+
width: '100%'}}>
616+
<iframe
617+
src="https://demo.arcade.software/gfbboO0ju21x2LhkksMy?embed&show_copy_link=true"
618+
title=""
619+
style={{
620+
position: 'absolute',
621+
top: 0,
622+
left: 0,
623+
width: '100%',
624+
height: '100%',
625+
colorScheme: 'light'
626+
}}
627+
frameborder="0"
628+
loading="lazy"
629+
webkitAllowFullScreen
630+
mozAllowFullScreen
631+
allowFullScreen
632+
allow="clipboard-write">
633+
</iframe>
634+
</div>
635+
<p></p>
604636

605637

606638
## Advanced Settings
@@ -739,3 +771,23 @@ If you prefer watching a video tutorial, here's the one for you:
739771
<div class="video-container"><iframe src="https://www.youtube.
740772
com/embed/L5qj2f9skt4" frameborder="0" allow="accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture; web-share" referrerpolicy="strict-origin-when-cross-origin" allowfullscreen></iframe></div>
741773
:::
774+
775+
776+
## FAQs
777+
<details>
778+
<summary>
779+
Why is my Predefined Path not showing any options?
780+
</summary>
781+
<p>
782+
This often happens if you added the Predefined Path but forgot to save the API call in FlutterFlow. Ensure you click Save after making any changes to your API call so FlutterFlow can properly recognize and display your predefined paths.
783+
</p>
784+
</details>
785+
786+
<details>
787+
<summary>
788+
Why am I getting a “Current variable is not valid” error?
789+
</summary>
790+
<p>
791+
This error typically indicates that the widget isn’t receiving the data type it expects. For example, passing a list of colors directly to a text widget will trigger the error. In such cases, convert or supply the data as a string (or another compatible type) so the widget can properly display it.
792+
</p>
793+
</details>

docs/resources/projects/libraries.md

Lines changed: 3 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -147,7 +147,7 @@ To import a library project into another FlutterFlow project, you must go to the
147147
- By default, the latest published version of the library is imported, but you can choose to depend on an earlier version if needed.
148148
- You can also import the `current` version of the library to use the latest state of the library on the main branch - however, this is not recommended.
149149
- You must have a paid plan to import a library.
150-
150+
- When importing a library into a project or another library, the library’s version must not be set to 'current' and should be less than or equal to the FlutterFlow version of the project or library it’s being imported into. Learn more about [**managing Library’s FlutterFlow version**](../projects/settings/version-management.md#version-management-with-libraries).
151151
:::
152152

153153

@@ -243,6 +243,8 @@ You can easily upgrade to newer versions of the libraries as they become availab
243243

244244
![update-library](imgs/update-library.avif)
245245

246+
247+
246248
## Library Values
247249

248250
**Library values** are essentially variables created and used by a library author and intended to have their values set by the library user. These values allow library author to create configurable variables that are useful in different contexts, such as API keys, global settings, or other project-specific configurations. These values allow library users to input specific data required for the library to function properly in their project.
Binary file not shown.
Binary file not shown.
58.5 KB
Loading
27.4 KB
Loading

0 commit comments

Comments
 (0)