Project tweaks (layout & docs) (#4121)

* Re-order the project groups.

* Update the instructions in FORKING.md.
This commit is contained in:
Doug
2025-05-15 14:39:08 +01:00
committed by GitHub
parent a27af2740b
commit 232d509cf9
3 changed files with 31 additions and 11 deletions

View File

@@ -1669,6 +1669,7 @@
3C368CAB3063EF275357ECD4 /* LoginScreenViewModel.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = LoginScreenViewModel.swift; sourceTree = "<group>"; };
3C3ADF21BE301D0DA48F2A7E /* ShareExtensionView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = ShareExtensionView.swift; sourceTree = "<group>"; };
3C3E67E09FE5A35D73818C39 /* AppLockScreenModels.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = AppLockScreenModels.swift; sourceTree = "<group>"; };
3C8A63F1458D97D832C127DD /* app.yml */ = {isa = PBXFileReference; lastKnownFileType = text.yaml; path = app.yml; sourceTree = "<group>"; };
3CCE3636E3D01477C8B2E9D0 /* ReportContentScreenModels.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = ReportContentScreenModels.swift; sourceTree = "<group>"; };
3CFD5EB0B0EEA4549FB49784 /* SettingsScreen.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SettingsScreen.swift; sourceTree = "<group>"; };
3D1D4A6D451F43A03CACD01D /* PINTextField.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = PINTextField.swift; sourceTree = "<group>"; };
@@ -3570,17 +3571,18 @@
405B00F139AEE3994601B36A = {
isa = PBXGroup;
children = (
3C8A63F1458D97D832C127DD /* app.yml */,
5D26A086A8278D39B5756D6F /* project.yml */,
99B9B46F2D621380428E68F7 /* ElementX */,
B04B538A859CD012755DC19C /* NSE */,
D0111119CDF3E28E6D7768E8 /* ShareExtension */,
A4852B57D55D71EEBFCD931D /* UnitTests */,
1803CD2B96BF06009334BB61 /* PreviewTests */,
C0FAC17D4DD7D3A502822550 /* UITests */,
8A9C09B6A392465E03B8D1B1 /* IntegrationTests */,
823ED0EC3F1B6CF47D284011 /* Tools */,
A8002CB4F20B6282850A614C /* DevelopmentAssets */,
B04B538A859CD012755DC19C /* NSE */,
1803CD2B96BF06009334BB61 /* PreviewTests */,
2197234282B4BC0CE79AAC74 /* Secrets */,
D0111119CDF3E28E6D7768E8 /* ShareExtension */,
823ED0EC3F1B6CF47D284011 /* Tools */,
681566846AF307E9BA4C72C6 /* Products */,
);
sourceTree = "<group>";

View File

@@ -1,15 +1,27 @@
# Forking
### Update the bundle identifier / app display name
### Project Configuration
To change the bundle identifier and the app display name for your app, open the `project.yml` file in the project root folder and change these settings:
To create a fork, the first step is to update some of the project's configuration options such as the bundle identifier and the app's display name. To do this, open the `app.yml` file in the project root folder and at a minimum change these settings:
```
BASE_BUNDLE_IDENTIFIER: io.element.elementx
APP_DISPLAY_NAME: Element X
APP_GROUP_IDENTIFIER: group.io.element
BASE_BUNDLE_IDENTIFIER: io.element.elementx
DEVELOPMENT_TEAM: 7J4U792NQT
```
After the changes run `xcodegen` to propagate them.
After making the changes, run `xcodegen` to regenerate the project.
### Runtime Configuration
Once your project is configured and compiles, you'll likely want to tweak how the app works. [AppSettings.swift](../ElementX/Sources/Application/AppSettings.swift) contains all of the settings used by the app at runtime.
### Authentication
Element X's primary authentication method is to use OIDC against [Matrix Authentication Service](https://github.com/element-hq/matrix-authentication-service) (MAS). Unlike the older password-based authentication flows, this requires a small amount of configuration within the app. You need to make sure that all of the values passed to the SDK in the [OIDCConfiguration](https://github.com/element-hq/element-x-ios/blob/b2a37ec9d39622586754f58a98dcda35e0e8cf7e/ElementX/Sources/Application/AppSettings.swift#L206-L212) are hosted on the same domain otherwise dynamic client registration will fail. As we're using an [HTTPS callback](https://developer.apple.com/documentation/authenticationservices/aswebauthenticationsession/callback/https(host:path:)) for the web authentication, Apple validates ownership of the domain with the app. There are 2 steps to make sure this validation works:
- Add an [apple-app-site-association](https://developer.apple.com/documentation/xcode/supporting-associated-domains) file on your website with your app included in the `webcredentials` section.
- Update the [webcredentials](https://github.com/element-hq/element-x-ios/blob/b2a37ec9d39622586754f58a98dcda35e0e8cf7e/ElementX/SupportingFiles/target.yml#L122) associated domain entitlement in the app to match your domain and re-run `xcodegen`.
### Setup the location sharing

View File

@@ -5,6 +5,7 @@ attributes:
fileGroups:
- project.yml
- app.yml
options:
groupSortPosition: bottom
@@ -15,9 +16,14 @@ options:
groupOrdering:
- order:
- ElementX
- NSE
- ShareExtension
- UnitTests
- PreviewTests
- UITests
- IntegrationTests
- DevelopmentAssets
- Secrets
- Tools
- pattern: ElementX
order:
@@ -69,6 +75,9 @@ packages:
url: https://github.com/matrix-org/matrix-analytics-events
minorVersion: 0.28.0
# path: ../matrix-analytics-events
EmbeddedElementCall:
url: https://github.com/element-hq/element-call-swift
exactVersion: 0.9.0
Emojibase:
url: https://github.com/matrix-org/emojibase-bindings
minorVersion: 1.4.1
@@ -81,9 +90,6 @@ packages:
url: https://github.com/element-hq/matrix-rich-text-editor-swift
exactVersion: 2.37.12
# path: ../matrix-rich-text-editor/platforms/ios/lib/WysiwygComposer
EmbeddedElementCall:
url: https://github.com/element-hq/element-call-swift
exactVersion: 0.9.0
# External dependencies
Algorithms: