Merge branch 'master' of https://gitee.com/starlock-cn/app-starlock
7
star_lock/.run/main_dev_dart.xml
Normal file
@ -0,0 +1,7 @@
|
|||||||
|
<component name="ProjectRunConfigurationManager">
|
||||||
|
<configuration default="false" name="main_dev.dart" type="FlutterRunConfigurationType" factoryName="Flutter">
|
||||||
|
<option name="buildFlavor" value="dev"/>
|
||||||
|
<option name="filePath" value="$PROJECT_DIR$/lib/main_dev.dart"/>
|
||||||
|
<method v="2"/>
|
||||||
|
</configuration>
|
||||||
|
</component>
|
||||||
7
star_lock/.run/main_pre_dart.xml
Normal file
@ -0,0 +1,7 @@
|
|||||||
|
<component name="ProjectRunConfigurationManager">
|
||||||
|
<configuration default="false" name="main_pre.dart" type="FlutterRunConfigurationType" factoryName="Flutter">
|
||||||
|
<option name="buildFlavor" value="pre"/>
|
||||||
|
<option name="filePath" value="$PROJECT_DIR$/lib/main_pre.dart"/>
|
||||||
|
<method v="2"/>
|
||||||
|
</configuration>
|
||||||
|
</component>
|
||||||
7
star_lock/.run/main_sky_dart.xml
Normal file
@ -0,0 +1,7 @@
|
|||||||
|
<component name="ProjectRunConfigurationManager">
|
||||||
|
<configuration default="false" name="main_sky.dart" type="FlutterRunConfigurationType" factoryName="Flutter">
|
||||||
|
<option name="buildFlavor" value="sky"/>
|
||||||
|
<option name="filePath" value="$PROJECT_DIR$/lib/main_sky.dart"/>
|
||||||
|
<method v="2"/>
|
||||||
|
</configuration>
|
||||||
|
</component>
|
||||||
7
star_lock/.run/main_xhj_dart.xml
Normal file
@ -0,0 +1,7 @@
|
|||||||
|
<component name="ProjectRunConfigurationManager">
|
||||||
|
<configuration default="false" name="main_xhj.dart" type="FlutterRunConfigurationType" factoryName="Flutter">
|
||||||
|
<option name="buildFlavor" value="xhj"/>
|
||||||
|
<option name="filePath" value="$PROJECT_DIR$/lib/main_xhj.dart"/>
|
||||||
|
<method v="2"/>
|
||||||
|
</configuration>
|
||||||
|
</component>
|
||||||
@ -28,6 +28,35 @@ apply plugin: 'kotlin-android'
|
|||||||
apply from: "$flutterRoot/packages/flutter_tools/gradle/flutter.gradle"
|
apply from: "$flutterRoot/packages/flutter_tools/gradle/flutter.gradle"
|
||||||
|
|
||||||
android {
|
android {
|
||||||
|
|
||||||
|
// ----- BEGIN flavorDimensions (autogenerated by flutter_flavorizr) -----
|
||||||
|
flavorDimensions "flavor-type"
|
||||||
|
|
||||||
|
productFlavors {
|
||||||
|
dev {
|
||||||
|
dimension "flavor-type"
|
||||||
|
applicationId "com.starlock.lock.dev"
|
||||||
|
resValue "string", "app_name", "星锁-dev"
|
||||||
|
}
|
||||||
|
pre {
|
||||||
|
dimension "flavor-type"
|
||||||
|
applicationId "com.starlock.lock.pre"
|
||||||
|
resValue "string", "app_name", "星锁"
|
||||||
|
}
|
||||||
|
sky {
|
||||||
|
dimension "flavor-type"
|
||||||
|
applicationId "com.skychip.lock"
|
||||||
|
resValue "string", "app_name", "锁通通"
|
||||||
|
}
|
||||||
|
xhj {
|
||||||
|
dimension "flavor-type"
|
||||||
|
applicationId "com.xhjcn.lock"
|
||||||
|
resValue "string", "app_name", "鑫锁"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// ----- END flavorDimensions (autogenerated by flutter_flavorizr) -----
|
||||||
|
|
||||||
compileSdkVersion flutter.compileSdkVersion
|
compileSdkVersion flutter.compileSdkVersion
|
||||||
ndkVersion flutter.ndkVersion
|
ndkVersion flutter.ndkVersion
|
||||||
|
|
||||||
|
|||||||
BIN
star_lock/android/app/src/dev/res/mipmap-hdpi/ic_launcher.png
Normal file
|
After Width: | Height: | Size: 4.0 KiB |
BIN
star_lock/android/app/src/dev/res/mipmap-mdpi/ic_launcher.png
Normal file
|
After Width: | Height: | Size: 2.6 KiB |
BIN
star_lock/android/app/src/dev/res/mipmap-xhdpi/ic_launcher.png
Normal file
|
After Width: | Height: | Size: 5.7 KiB |
BIN
star_lock/android/app/src/dev/res/mipmap-xxhdpi/ic_launcher.png
Normal file
|
After Width: | Height: | Size: 9.2 KiB |
BIN
star_lock/android/app/src/dev/res/mipmap-xxxhdpi/ic_launcher.png
Normal file
|
After Width: | Height: | Size: 13 KiB |
@ -1,110 +1,78 @@
|
|||||||
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
|
<manifest xmlns:android="http://schemas.android.com/apk/res/android" package="com.example.star_lock">
|
||||||
package="com.example.star_lock">
|
<uses-permission android:name="android.permission.BLUETOOTH_SCAN" android:usesPermissionFlags="neverForLocation"/>
|
||||||
|
<uses-permission android:name="android.permission.BLUETOOTH_CONNECT"/>
|
||||||
<uses-permission android:name="android.permission.BLUETOOTH_SCAN" android:usesPermissionFlags="neverForLocation" />
|
<!-- <uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" android:maxSdkVersion="30" />-->
|
||||||
<uses-permission android:name="android.permission.BLUETOOTH_CONNECT" />
|
<!-- <uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION" android:maxSdkVersion="30" />-->
|
||||||
<!-- <uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" android:maxSdkVersion="30" />-->
|
<!--允许访问网络,必选权限-->
|
||||||
<!-- <uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION" android:maxSdkVersion="30" />-->
|
<uses-permission android:name="android.permission.INTERNET"/>
|
||||||
|
<!--允许获取精确位置,精准定位必选-->
|
||||||
<!--允许访问网络,必选权限-->
|
<uses-permission android:name="android.permission.ACCESS_FINE_LOCATION"/>
|
||||||
<uses-permission android:name="android.permission.INTERNET" />
|
<!--允许获取粗略位置,粗略定位必选-->
|
||||||
<!--允许获取精确位置,精准定位必选-->
|
<uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION"/>
|
||||||
<uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" />
|
<!--允许获取设备和运营商信息,用于问题排查和网络定位(无gps情况下的定位),若需网络定位功能则必选-->
|
||||||
<!--允许获取粗略位置,粗略定位必选-->
|
<uses-permission android:name="android.permission.READ_PHONE_STATE"/>
|
||||||
<uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION" />
|
<uses-permission android:name="android.permission.READ_PHONE_NUMBERS"/>
|
||||||
|
<!--允许获取网络状态,用于网络定位(无gps情况下的定位),若需网络定位功能则必选-->
|
||||||
<!--允许获取设备和运营商信息,用于问题排查和网络定位(无gps情况下的定位),若需网络定位功能则必选-->
|
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE"/>
|
||||||
<uses-permission android:name="android.permission.READ_PHONE_STATE" />
|
<!--允许获取wifi网络信息,用于网络定位(无gps情况下的定位),若需网络定位功能则必选-->
|
||||||
<uses-permission android:name="android.permission.READ_PHONE_NUMBERS" />
|
<uses-permission android:name="android.permission.ACCESS_WIFI_STATE"/>
|
||||||
|
<!--允许获取wifi状态改变,用于网络定位(无gps情况下的定位),若需网络定位功能则必选-->
|
||||||
<!--允许获取网络状态,用于网络定位(无gps情况下的定位),若需网络定位功能则必选-->
|
<uses-permission android:name="android.permission.CHANGE_WIFI_STATE"/>
|
||||||
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
|
<!--后台获取位置信息,若需后台定位则必选-->
|
||||||
|
<!-- <uses-permission android:name="android.permission.ACCESS_BACKGROUND_LOCATION" />-->
|
||||||
<!--允许获取wifi网络信息,用于网络定位(无gps情况下的定位),若需网络定位功能则必选-->
|
<!--用于申请调用A-GPS模块,卫星定位加速-->
|
||||||
<uses-permission android:name="android.permission.ACCESS_WIFI_STATE" />
|
<!-- <uses-permission android:name="android.permission.ACCESS_LOCATION_EXTRA_COMMANDS" />-->
|
||||||
|
<!--允许写设备缓存,用于问题排查-->
|
||||||
<!--允许获取wifi状态改变,用于网络定位(无gps情况下的定位),若需网络定位功能则必选-->
|
<uses-permission android:name="android.permission.WRITE_SETTINGS"/>
|
||||||
<uses-permission android:name="android.permission.CHANGE_WIFI_STATE" />
|
<!--允许写入扩展存储,用于写入缓存定位数据-->
|
||||||
|
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>
|
||||||
<!--后台获取位置信息,若需后台定位则必选-->
|
<!--允许读设备等信息,用于问题排查-->
|
||||||
<!-- <uses-permission android:name="android.permission.ACCESS_BACKGROUND_LOCATION" />-->
|
<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE"/>
|
||||||
|
<!--允许麦克风权限,用于录音发送-->
|
||||||
<!--用于申请调用A-GPS模块,卫星定位加速-->
|
<uses-permission android:name="android.permission.RECORD_AUDIO"/>
|
||||||
<!-- <uses-permission android:name="android.permission.ACCESS_LOCATION_EXTRA_COMMANDS" />-->
|
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>
|
||||||
|
<uses-permission android:name="android.permission.WAKE_LOCK"/>
|
||||||
<!--允许写设备缓存,用于问题排查-->
|
<uses-permission android:name="android.permission.GET_ACCOUNTS"/>
|
||||||
<uses-permission android:name="android.permission.WRITE_SETTINGS" />
|
<uses-permission android:name="android.permission.RECEIVE_BOOT_COMPLETED"/>
|
||||||
|
<uses-permission android:name="android.permission.VIBRATE"/>
|
||||||
<!--允许写入扩展存储,用于写入缓存定位数据-->
|
<uses-permission android:name="android.permission.REORDER_TASKS"/>
|
||||||
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
|
<application android:label="@string/app_name" android:name="${applicationName}" android:icon="@mipmap/ic_launcher">
|
||||||
|
<!-- 配置定位Service -->
|
||||||
<!--允许读设备等信息,用于问题排查-->
|
<service android:name="com.amap.api.location.APSService"/>
|
||||||
<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" />
|
<activity android:name="cn.starlock.lock.MainActivity" android:exported="true" android:screenOrientation="portrait" android:launchMode="singleTop" android:theme="@style/LaunchTheme" android:configChanges="orientation|keyboardHidden|keyboard|screenSize|smallestScreenSize|locale|layoutDirection|fontScale|screenLayout|density|uiMode" android:hardwareAccelerated="true" android:windowSoftInputMode="adjustResize">
|
||||||
|
<!-- Specifies an Android theme to apply to this Activity as soon as
|
||||||
<!--允许麦克风权限,用于录音发送-->
|
|
||||||
<uses-permission android:name="android.permission.RECORD_AUDIO" />
|
|
||||||
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
|
|
||||||
<uses-permission android:name="android.permission.WAKE_LOCK" />
|
|
||||||
<uses-permission android:name="android.permission.GET_ACCOUNTS" />
|
|
||||||
<uses-permission android:name="android.permission.RECEIVE_BOOT_COMPLETED" />
|
|
||||||
<uses-permission android:name="android.permission.VIBRATE" />
|
|
||||||
<uses-permission android:name="android.permission.REORDER_TASKS" />
|
|
||||||
|
|
||||||
<application
|
|
||||||
android:label="星锁"
|
|
||||||
android:name="${applicationName}"
|
|
||||||
android:icon="@mipmap/ic_logo">
|
|
||||||
<!-- 配置定位Service -->
|
|
||||||
<service android:name="com.amap.api.location.APSService"/>
|
|
||||||
<activity
|
|
||||||
android:name="cn.starlock.lock.MainActivity"
|
|
||||||
android:exported="true"
|
|
||||||
android:screenOrientation="portrait"
|
|
||||||
android:launchMode="singleTop"
|
|
||||||
android:theme="@style/LaunchTheme"
|
|
||||||
android:configChanges="orientation|keyboardHidden|keyboard|screenSize|smallestScreenSize|locale|layoutDirection|fontScale|screenLayout|density|uiMode"
|
|
||||||
android:hardwareAccelerated="true"
|
|
||||||
android:windowSoftInputMode="adjustResize">
|
|
||||||
<!-- Specifies an Android theme to apply to this Activity as soon as
|
|
||||||
the Android process has started. This theme is visible to the user
|
the Android process has started. This theme is visible to the user
|
||||||
while the Flutter UI initializes. After that, this theme continues
|
while the Flutter UI initializes. After that, this theme continues
|
||||||
to determine the Window background behind the Flutter UI. -->
|
to determine the Window background behind the Flutter UI. -->
|
||||||
<meta-data
|
<meta-data android:name="io.flutter.embedding.android.NormalTheme" android:resource="@style/NormalTheme"/>
|
||||||
android:name="io.flutter.embedding.android.NormalTheme"
|
<intent-filter>
|
||||||
android:resource="@style/NormalTheme"
|
<action android:name="android.intent.action.MAIN"/>
|
||||||
/>
|
<category android:name="android.intent.category.LAUNCHER"/>
|
||||||
<intent-filter>
|
</intent-filter>
|
||||||
<action android:name="android.intent.action.MAIN"/>
|
</activity>
|
||||||
<category android:name="android.intent.category.LAUNCHER"/>
|
<!-- Don't delete the meta-data below.
|
||||||
</intent-filter>
|
|
||||||
|
|
||||||
</activity>
|
|
||||||
<!-- Don't delete the meta-data below.
|
|
||||||
This is used by the Flutter tool to generate GeneratedPluginRegistrant.java -->
|
This is used by the Flutter tool to generate GeneratedPluginRegistrant.java -->
|
||||||
<meta-data
|
<meta-data android:name="flutterEmbedding" android:value="2"/>
|
||||||
android:name="flutterEmbedding"
|
<meta-data android:name="com.amap.api.v2.apikey" android:value="11d49b3f4fc09c04a02bbb7500925ba2"></meta-data>
|
||||||
android:value="2" />
|
<!-- 请填写你自己的- appKey -->
|
||||||
<meta-data android:name="com.amap.api.v2.apikey" android:value="11d49b3f4fc09c04a02bbb7500925ba2"> </meta-data>
|
<meta-data android:name="com.alibaba.app.appkey" android:value="333904040"/>
|
||||||
<!-- 请填写你自己的- appKey -->
|
<!-- 请填写你自己的appSecret -->
|
||||||
<meta-data android:name="com.alibaba.app.appkey" android:value="333904040"/>
|
<meta-data android:name="com.alibaba.app.appsecret" android:value="c316965fe0a74fc9a481a5c44a535dc2"/>
|
||||||
<!-- 请填写你自己的appSecret -->
|
<!-- 消息接收监听器 (用户可自主扩展) -->
|
||||||
<meta-data android:name="com.alibaba.app.appsecret" android:value="c316965fe0a74fc9a481a5c44a535dc2"/>
|
<receiver android:name="cn.starlock.lock.MyMessageReceiver" android:exported="false">
|
||||||
<!-- 消息接收监听器 (用户可自主扩展) -->
|
<!-- 为保证receiver安全,建议设置不可导出,如需对其他应用开放可通过android:permission进行限制 -->
|
||||||
<receiver
|
<intent-filter>
|
||||||
android:name="cn.starlock.lock.MyMessageReceiver"
|
<action android:name="com.alibaba.sdk.android.push.intent.MESSAGE"/>
|
||||||
android:exported="false" > <!-- 为保证receiver安全,建议设置不可导出,如需对其他应用开放可通过android:permission进行限制 -->
|
</intent-filter>
|
||||||
<intent-filter>
|
<intent-filter>
|
||||||
<action android:name="com.alibaba.sdk.android.push.intent.MESSAGE" />
|
<action android:name="com.alibaba.push2.action.NOTIFICATION_OPENED"/>
|
||||||
</intent-filter>
|
</intent-filter>
|
||||||
<intent-filter>
|
<intent-filter>
|
||||||
<action android:name="com.alibaba.push2.action.NOTIFICATION_OPENED" />
|
<action android:name="com.alibaba.push2.action.NOTIFICATION_REMOVED"/>
|
||||||
</intent-filter>
|
</intent-filter>
|
||||||
<intent-filter>
|
<intent-filter>
|
||||||
<action android:name="com.alibaba.push2.action.NOTIFICATION_REMOVED" />
|
<action android:name="com.alibaba.sdk.android.push.RECEIVE"/>
|
||||||
</intent-filter>
|
</intent-filter>
|
||||||
<intent-filter>
|
</receiver>
|
||||||
<action android:name="com.alibaba.sdk.android.push.RECEIVE" />
|
</application>
|
||||||
</intent-filter>
|
|
||||||
</receiver>
|
|
||||||
</application>
|
|
||||||
</manifest>
|
</manifest>
|
||||||
|
|||||||
@ -7,6 +7,6 @@
|
|||||||
<item>
|
<item>
|
||||||
<bitmap
|
<bitmap
|
||||||
android:gravity="center"
|
android:gravity="center"
|
||||||
android:src="@mipmap/ic_logo" />
|
android:src="@mipmap/ic_launcher" />
|
||||||
</item>
|
</item>
|
||||||
</layer-list>
|
</layer-list>
|
||||||
|
|||||||
@ -7,6 +7,6 @@
|
|||||||
<item>
|
<item>
|
||||||
<bitmap
|
<bitmap
|
||||||
android:gravity="center"
|
android:gravity="center"
|
||||||
android:src="@mipmap/ic_logo" />
|
android:src="@mipmap/ic_launcher" />
|
||||||
</item>
|
</item>
|
||||||
</layer-list>
|
</layer-list>
|
||||||
|
|||||||
|
Before Width: | Height: | Size: 3.6 KiB |
|
Before Width: | Height: | Size: 1.1 KiB |
|
Before Width: | Height: | Size: 1.4 KiB |
|
Before Width: | Height: | Size: 5.0 KiB |
|
Before Width: | Height: | Size: 7.9 KiB |
|
Before Width: | Height: | Size: 11 KiB |
BIN
star_lock/android/app/src/pre/res/mipmap-hdpi/ic_launcher.png
Normal file
|
After Width: | Height: | Size: 3.9 KiB |
BIN
star_lock/android/app/src/pre/res/mipmap-mdpi/ic_launcher.png
Normal file
|
After Width: | Height: | Size: 2.4 KiB |
BIN
star_lock/android/app/src/pre/res/mipmap-xhdpi/ic_launcher.png
Normal file
|
After Width: | Height: | Size: 5.4 KiB |
BIN
star_lock/android/app/src/pre/res/mipmap-xxhdpi/ic_launcher.png
Normal file
|
After Width: | Height: | Size: 9.4 KiB |
BIN
star_lock/android/app/src/pre/res/mipmap-xxxhdpi/ic_launcher.png
Normal file
|
After Width: | Height: | Size: 13 KiB |
BIN
star_lock/android/app/src/sky/res/mipmap-hdpi/ic_launcher.png
Normal file
|
After Width: | Height: | Size: 2.3 KiB |
BIN
star_lock/android/app/src/sky/res/mipmap-mdpi/ic_launcher.png
Normal file
|
After Width: | Height: | Size: 1.4 KiB |
BIN
star_lock/android/app/src/sky/res/mipmap-xhdpi/ic_launcher.png
Normal file
|
After Width: | Height: | Size: 3.1 KiB |
BIN
star_lock/android/app/src/sky/res/mipmap-xxhdpi/ic_launcher.png
Normal file
|
After Width: | Height: | Size: 4.7 KiB |
BIN
star_lock/android/app/src/sky/res/mipmap-xxxhdpi/ic_launcher.png
Normal file
|
After Width: | Height: | Size: 6.5 KiB |
BIN
star_lock/android/app/src/xhj/res/mipmap-hdpi/ic_launcher.png
Normal file
|
After Width: | Height: | Size: 2.7 KiB |
BIN
star_lock/android/app/src/xhj/res/mipmap-mdpi/ic_launcher.png
Normal file
|
After Width: | Height: | Size: 1.6 KiB |
BIN
star_lock/android/app/src/xhj/res/mipmap-xhdpi/ic_launcher.png
Normal file
|
After Width: | Height: | Size: 3.8 KiB |
BIN
star_lock/android/app/src/xhj/res/mipmap-xxhdpi/ic_launcher.png
Normal file
|
After Width: | Height: | Size: 6.0 KiB |
BIN
star_lock/android/app/src/xhj/res/mipmap-xxxhdpi/ic_launcher.png
Normal file
|
After Width: | Height: | Size: 8.4 KiB |
BIN
star_lock/assets/icon/dev.png
Normal file
|
After Width: | Height: | Size: 46 KiB |
BIN
star_lock/assets/icon/pre.png
Normal file
|
After Width: | Height: | Size: 42 KiB |
BIN
star_lock/assets/icon/sky.png
Normal file
|
After Width: | Height: | Size: 18 KiB |
BIN
star_lock/assets/icon/xhj.png
Normal file
|
After Width: | Height: | Size: 61 KiB |
54
star_lock/flavorizr.yaml
Normal file
@ -0,0 +1,54 @@
|
|||||||
|
# 用于编译出不同的APPID
|
||||||
|
|
||||||
|
# 生成:意思是将本文件定义的配置,生成对应的代码,或者原生的配置、构建过程、文件资源等
|
||||||
|
# 风味用法:dart run flutter_flavorizr -p <processor_1>,<processor_2>
|
||||||
|
|
||||||
|
# 以下行为都是覆盖,所以如果不是很清楚自己在做什么,请不要随意运行,以免覆盖有用的文件
|
||||||
|
# 安卓图标:dart run flutter_flavorizr -p android:icons
|
||||||
|
# 安卓构建参数集配置:dart run flutter_flavorizr -p android:androidManifest
|
||||||
|
# 安卓构建目标配置:dart run flutter_flavorizr -p android:buildGradle
|
||||||
|
# iOS图标:dart run flutter_flavorizr -
|
||||||
|
# iOS构建参数集配置:dart run flutter_flavorizr -
|
||||||
|
# iOS构建目标配置:dart run flutter_flavorizr -
|
||||||
|
|
||||||
|
# 项目运行说明:添加不同风味后,不能再使用flutter默认的运行方式`flutter run`,而是需要指定运行的风味
|
||||||
|
# flutter run --flavor <flavor> -t lib/main_<flavor>.dart
|
||||||
|
# 注意,这里有 入口文件(main_<flavor>.dart) 和 口味(<flavor>) 两个参数
|
||||||
|
# 其中入口文件在代码中指定运行时的差异,例如 页面上的名称、颜色、API请求的域名等
|
||||||
|
# 而 口味 指定 构建差异,例如 APPID、Logo、应用名称等
|
||||||
|
# 下面是4个运行示例:
|
||||||
|
# flutter run --flavor dev -t lib/main_dev.dart
|
||||||
|
# flutter run --flavor pre -t lib/main_pre.dart
|
||||||
|
# flutter run --flavor sky -t lib/main_sky.dart
|
||||||
|
# flutter run --flavor xhj -t lib/main_xhj.dart
|
||||||
|
|
||||||
|
app:
|
||||||
|
android:
|
||||||
|
flavorDimensions: "flavor-type"
|
||||||
|
|
||||||
|
flavors:
|
||||||
|
dev:
|
||||||
|
app:
|
||||||
|
name: "星锁-dev"
|
||||||
|
icon: "assets/icon/dev.png"
|
||||||
|
android:
|
||||||
|
applicationId: "com.starlock.lock.dev"
|
||||||
|
pre:
|
||||||
|
app:
|
||||||
|
name: "星锁"
|
||||||
|
icon: "assets/icon/pre.png"
|
||||||
|
android:
|
||||||
|
applicationId: "com.starlock.lock.pre"
|
||||||
|
sky:
|
||||||
|
app:
|
||||||
|
name: "锁通通"
|
||||||
|
icon: "assets/icon/sky.png"
|
||||||
|
android:
|
||||||
|
applicationId: "com.skychip.lock"
|
||||||
|
xhj:
|
||||||
|
app:
|
||||||
|
name: "鑫锁"
|
||||||
|
icon: "assets/icon/xhj.png"
|
||||||
|
android:
|
||||||
|
applicationId: "com.xhjcn.lock"
|
||||||
|
ide: idea
|
||||||
BIN
star_lock/images/main/icon_lockLog_play.png
Normal file
|
After Width: | Height: | Size: 1.3 KiB |
177
star_lock/lib/app.dart
Normal file
@ -0,0 +1,177 @@
|
|||||||
|
import 'package:aliyun_push/aliyun_push.dart';
|
||||||
|
import 'package:flutter/material.dart';
|
||||||
|
import 'package:flutter_easyloading/flutter_easyloading.dart';
|
||||||
|
import 'package:flutter_localizations/flutter_localizations.dart';
|
||||||
|
import 'package:flutter_screenutil/flutter_screenutil.dart';
|
||||||
|
import 'package:get/get.dart';
|
||||||
|
import 'package:permission_handler/permission_handler.dart';
|
||||||
|
import 'package:star_lock/tools/app_manager.dart';
|
||||||
|
import 'package:star_lock/tools/bindings/app_binding.dart';
|
||||||
|
|
||||||
|
import 'package:star_lock/tools/storage.dart';
|
||||||
|
import 'package:star_lock/tools/xs_aliyunPush.dart';
|
||||||
|
import 'package:star_lock/translations/app_dept.dart';
|
||||||
|
import 'package:star_lock/translations/trans_lib.dart';
|
||||||
|
|
||||||
|
import 'appRouters.dart';
|
||||||
|
import 'baseWidget.dart';
|
||||||
|
import 'tools/appRouteObserver.dart';
|
||||||
|
import 'dart:io';
|
||||||
|
import 'package:flutter/services.dart';
|
||||||
|
|
||||||
|
class MyApp extends StatefulWidget {
|
||||||
|
const MyApp({GlobalKey? key}) : super(key: key);
|
||||||
|
|
||||||
|
@override
|
||||||
|
State<MyApp> createState() => _MyAppState();
|
||||||
|
}
|
||||||
|
|
||||||
|
// 注册 RouteObserver 作为 navigation observer.
|
||||||
|
// final RouteObserver<PageRoute> routeObserver = RouteObserver<PageRoute>();
|
||||||
|
|
||||||
|
class _MyAppState extends State<MyApp> with WidgetsBindingObserver, BaseWidget {
|
||||||
|
@override
|
||||||
|
Widget build(BuildContext context) {
|
||||||
|
return ScreenUtilInit(
|
||||||
|
designSize: const Size(585, 1265),
|
||||||
|
builder: (w, a) => _initMaterialApp());
|
||||||
|
}
|
||||||
|
|
||||||
|
GetMaterialApp _initMaterialApp() => GetMaterialApp(
|
||||||
|
title: 'Star Lock',
|
||||||
|
navigatorObservers: [AppRouteObserver().routeObserver],
|
||||||
|
translations: TranslationMessage(),
|
||||||
|
supportedLocales: appDept.deptSupportedLocales,
|
||||||
|
localizationsDelegates: const [
|
||||||
|
GlobalMaterialLocalizations.delegate,
|
||||||
|
GlobalCupertinoLocalizations.delegate,
|
||||||
|
GlobalWidgetsLocalizations.delegate,
|
||||||
|
],
|
||||||
|
localeResolutionCallback: (locale, supportedLocales) {
|
||||||
|
if (!supportedLocales.contains(locale)) {
|
||||||
|
int idx = appSupportedLocales.indexWhere(
|
||||||
|
(element) => element.languageCode == locale!.languageCode);
|
||||||
|
if (idx != -1) {
|
||||||
|
locale = appSupportedLocales[idx];
|
||||||
|
} else {
|
||||||
|
locale = const Locale('zh', 'CN');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// print("localelocalelocalelocalelocale locale:${locale} locale.languageCode:${locale.languageCode} locale.countryCode:${locale.countryCode} supportedLocales:${supportedLocales}");
|
||||||
|
AppManager()
|
||||||
|
.setLanCode(code: '${locale!.languageCode}_${locale.countryCode}');
|
||||||
|
return locale;
|
||||||
|
},
|
||||||
|
// locale: StoreService.to.getLanguageCode().isNotEmpty ? appDept.deptSupportedLocales.where((element) => element.languageCode == StoreService.to.getLanguageCode()).first : Get.deviceLocale,
|
||||||
|
locale: Get.deviceLocale,
|
||||||
|
fallbackLocale: const Locale('zh', 'CN'),
|
||||||
|
theme: ThemeData(
|
||||||
|
scaffoldBackgroundColor: const Color(0xFFF6F6F6),
|
||||||
|
backgroundColor: const Color(0xFFF6F6F6),
|
||||||
|
primaryColor: const Color(0xFFFFFFFF),
|
||||||
|
textTheme: TextTheme(
|
||||||
|
//用在非Material组件上的文字显示,
|
||||||
|
bodyText1:
|
||||||
|
TextStyle(fontSize: 28.sp, color: const Color(0xff2E2B2B)),
|
||||||
|
//Material组件上的文字显示
|
||||||
|
bodyText2:
|
||||||
|
TextStyle(fontSize: 28.sp, color: const Color(0xff2E2B2B)),
|
||||||
|
button: TextStyle(fontSize: 28.sp)),
|
||||||
|
iconTheme: IconThemeData(size: 28.sp, color: const Color(0xff2E2B2B)),
|
||||||
|
appBarTheme: AppBarTheme(
|
||||||
|
backgroundColor: const Color(0xFFFFFFFF),
|
||||||
|
elevation: 0,
|
||||||
|
centerTitle: true,
|
||||||
|
iconTheme: IconThemeData(color: const Color(0xff333333), size: 36.sp),
|
||||||
|
titleTextStyle: TextStyle(
|
||||||
|
color: const Color(0xff333333),
|
||||||
|
fontWeight: FontWeight.w400,
|
||||||
|
fontSize: 36.sp),
|
||||||
|
),
|
||||||
|
splashColor: Colors.transparent, // 点击时的高亮效果设置为透明
|
||||||
|
highlightColor: Colors.transparent,
|
||||||
|
),
|
||||||
|
debugShowCheckedModeBanner: false,
|
||||||
|
getPages: AppRouters.routePages,
|
||||||
|
builder: EasyLoading.init(),
|
||||||
|
initialBinding: AppBindings(),
|
||||||
|
initialRoute: '/');
|
||||||
|
|
||||||
|
@override
|
||||||
|
void initState() {
|
||||||
|
super.initState();
|
||||||
|
WidgetsBinding.instance.addObserver(this);
|
||||||
|
|
||||||
|
openBlueScan();
|
||||||
|
|
||||||
|
initAliyunPush();
|
||||||
|
}
|
||||||
|
|
||||||
|
//初始化阿里云推送
|
||||||
|
void initAliyunPush() {
|
||||||
|
final aliyunPush = AliyunPush();
|
||||||
|
XSAliyunPushProvider().init(aliyunPush);
|
||||||
|
XSAliyunPushProvider().initAliyunPush();
|
||||||
|
|
||||||
|
if (Platform.isAndroid) {
|
||||||
|
XSAliyunPushProvider().initAliyunThirdPush();
|
||||||
|
}
|
||||||
|
|
||||||
|
//暂使用DeviceID推送
|
||||||
|
aliyunPush.getDeviceId().then((deviceId) async {
|
||||||
|
// print('得到的DeviceId$deviceId');
|
||||||
|
final data = await Storage.getString(saveUserLoginData);
|
||||||
|
if (data!.isNotEmpty && deviceId.isNotEmpty) {
|
||||||
|
XSAliyunPushProvider()
|
||||||
|
.pushBindDeviceID(deviceId, Platform.isAndroid ? 10 : 20);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
@override
|
||||||
|
void dispose() {
|
||||||
|
WidgetsBinding.instance.removeObserver(this);
|
||||||
|
super.dispose();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void openBlueScan() {
|
||||||
|
if (Platform.isIOS) {
|
||||||
|
print("有蓝牙权限开始扫描");
|
||||||
|
// startScanAction();
|
||||||
|
} else {
|
||||||
|
getMicrophonePermission().then((value) {
|
||||||
|
if (value) {
|
||||||
|
// 有权限
|
||||||
|
print("有蓝牙权限开始扫描");
|
||||||
|
// startScanAction();
|
||||||
|
} else {
|
||||||
|
//没有权限
|
||||||
|
openAppSettings(); //打开app系统设置
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// void startScanAction() {
|
||||||
|
// BlueManage().startScan();
|
||||||
|
// }
|
||||||
|
|
||||||
|
///请求蓝牙权限
|
||||||
|
Future<bool> getMicrophonePermission() async {
|
||||||
|
// You can request multiple permissions at once.
|
||||||
|
Map<Permission, PermissionStatus> statuses = await [
|
||||||
|
Permission.bluetoothScan,
|
||||||
|
Permission.bluetoothConnect,
|
||||||
|
Permission.location,
|
||||||
|
].request();
|
||||||
|
|
||||||
|
//granted 通过,denied 被拒绝,permanentlyDenied 拒绝且不在提示
|
||||||
|
if (statuses[Permission.bluetoothScan]!.isGranted &&
|
||||||
|
statuses[Permission.bluetoothConnect]!.isGranted &&
|
||||||
|
statuses[Permission.location]!.isGranted) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
@ -1,8 +1,8 @@
|
|||||||
import 'package:star_lock/network/api.dart';
|
import '../../flavors.dart';
|
||||||
|
|
||||||
class XSConstantMacro {
|
class XSConstantMacro {
|
||||||
// 网页的宏定义网址
|
// 网页的宏定义网址
|
||||||
static String baseWebURL = Api.baseAddress; //base地址
|
static String baseWebURL = F.apiPrefix; //base地址
|
||||||
static String introduceURL = '$baseWebURL/app/introduce'; //介绍页
|
static String introduceURL = '$baseWebURL/app/introduce'; //介绍页
|
||||||
static String userAgreementURL = '$baseWebURL/app/userAgreement'; //用户协议
|
static String userAgreementURL = '$baseWebURL/app/userAgreement'; //用户协议
|
||||||
static String privacyPolicyURL = '$baseWebURL/app/privacy'; //隐私政策
|
static String privacyPolicyURL = '$baseWebURL/app/privacy'; //隐私政策
|
||||||
|
|||||||
43
star_lock/lib/flavors.dart
Normal file
@ -0,0 +1,43 @@
|
|||||||
|
enum Flavor {
|
||||||
|
dev,
|
||||||
|
pre,
|
||||||
|
sky,
|
||||||
|
xhj,
|
||||||
|
}
|
||||||
|
|
||||||
|
class F {
|
||||||
|
static Flavor? appFlavor;
|
||||||
|
|
||||||
|
static String get name => appFlavor?.name ?? '';
|
||||||
|
|
||||||
|
static String get title {
|
||||||
|
switch (appFlavor) {
|
||||||
|
case Flavor.dev:
|
||||||
|
return '星锁-dev';
|
||||||
|
case Flavor.pre:
|
||||||
|
return '星锁-pre';
|
||||||
|
case Flavor.sky:
|
||||||
|
return '锁通通';
|
||||||
|
case Flavor.xhj:
|
||||||
|
return '鑫锁';
|
||||||
|
default:
|
||||||
|
throw Exception('flavor[$name] title not found');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
static String get apiPrefix {
|
||||||
|
switch (appFlavor) {
|
||||||
|
case Flavor.dev:
|
||||||
|
return 'https://dev.lock.star-lock.cn';
|
||||||
|
case Flavor.pre:
|
||||||
|
return 'https://pre.lock.star-lock.cn';
|
||||||
|
case Flavor.sky:
|
||||||
|
return 'https://lock.skychip.top';
|
||||||
|
case Flavor.xhj:
|
||||||
|
return 'https://lock.xhjcn.ltd';
|
||||||
|
default:
|
||||||
|
// "http://192.168.1.15:8022"; //谢总本地
|
||||||
|
// "https://ge.lock.star-lock.cn"; //葛工开发环境地址
|
||||||
|
throw Exception('flavor[$name] apiPrefix not found');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@ -1,28 +1,16 @@
|
|||||||
import 'package:aliyun_push/aliyun_push.dart';
|
import 'dart:async';
|
||||||
import 'package:flutter/material.dart';
|
import 'package:flutter/material.dart';
|
||||||
import 'package:flutter_easyloading/flutter_easyloading.dart';
|
import 'package:flutter/services.dart';
|
||||||
import 'package:flutter_localizations/flutter_localizations.dart';
|
import 'package:star_lock/translations/trans_lib.dart';
|
||||||
import 'package:flutter_screenutil/flutter_screenutil.dart';
|
import 'app.dart';
|
||||||
import 'package:get/get.dart';
|
|
||||||
import 'package:permission_handler/permission_handler.dart';
|
|
||||||
import 'package:star_lock/tools/app_manager.dart';
|
|
||||||
import 'package:star_lock/tools/bindings/app_binding.dart';
|
|
||||||
import 'package:star_lock/tools/device_info_service.dart';
|
import 'package:star_lock/tools/device_info_service.dart';
|
||||||
import 'package:star_lock/tools/platform_info_services.dart';
|
import 'package:star_lock/tools/platform_info_services.dart';
|
||||||
import 'package:star_lock/tools/storage.dart';
|
import 'app_settings/app_settings.dart';
|
||||||
import 'package:star_lock/tools/xs_aliyunPush.dart';
|
|
||||||
import 'package:star_lock/translations/app_dept.dart';
|
|
||||||
import 'package:star_lock/translations/trans_lib.dart';
|
|
||||||
|
|
||||||
import 'appRouters.dart';
|
|
||||||
import 'baseWidget.dart';
|
|
||||||
import 'blue/blue_manage.dart';
|
|
||||||
import 'tools/appRouteObserver.dart';
|
|
||||||
import 'tools/store_service.dart';
|
import 'tools/store_service.dart';
|
||||||
import 'dart:io';
|
import 'package:get/get.dart';
|
||||||
import 'package:flutter/services.dart';
|
|
||||||
|
|
||||||
void main() async {
|
// 该文件不可作为编译入口,请查看 flavorizr.yaml 中的说明
|
||||||
|
FutureOr<void> main() async {
|
||||||
await _setCommonServices();
|
await _setCommonServices();
|
||||||
|
|
||||||
// 设置国际化信息
|
// 设置国际化信息
|
||||||
@ -30,135 +18,19 @@ void main() async {
|
|||||||
|
|
||||||
runApp(MyApp());
|
runApp(MyApp());
|
||||||
|
|
||||||
if (Platform.isAndroid) {
|
if (AppPlatform.isAndroid) {
|
||||||
SystemUiOverlayStyle systemUiOverlayStyle =
|
SystemUiOverlayStyle systemUiOverlayStyle =
|
||||||
const SystemUiOverlayStyle(statusBarColor: Colors.transparent);
|
const SystemUiOverlayStyle(statusBarColor: Colors.transparent);
|
||||||
SystemChrome.setSystemUIOverlayStyle(systemUiOverlayStyle);
|
SystemChrome.setSystemUIOverlayStyle(systemUiOverlayStyle);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
class MyApp extends StatefulWidget {
|
|
||||||
const MyApp({GlobalKey? key}) : super(key: key);
|
|
||||||
|
|
||||||
@override
|
|
||||||
State<MyApp> createState() => _MyAppState();
|
|
||||||
}
|
|
||||||
|
|
||||||
// 注册 RouteObserver 作为 navigation observer.
|
|
||||||
// final RouteObserver<PageRoute> routeObserver = RouteObserver<PageRoute>();
|
|
||||||
|
|
||||||
class _MyAppState extends State<MyApp> with WidgetsBindingObserver, BaseWidget {
|
|
||||||
@override
|
|
||||||
Widget build(BuildContext context) {
|
|
||||||
return ScreenUtilInit(
|
|
||||||
designSize: const Size(585, 1265),
|
|
||||||
builder: (w, a) => _initMaterialApp());
|
|
||||||
}
|
|
||||||
|
|
||||||
GetMaterialApp _initMaterialApp() => GetMaterialApp(
|
|
||||||
title: 'Star Lock',
|
|
||||||
navigatorObservers: [AppRouteObserver().routeObserver],
|
|
||||||
translations: TranslationMessage(),
|
|
||||||
supportedLocales: appDept.deptSupportedLocales,
|
|
||||||
localizationsDelegates: const [
|
|
||||||
GlobalMaterialLocalizations.delegate,
|
|
||||||
GlobalCupertinoLocalizations.delegate,
|
|
||||||
GlobalWidgetsLocalizations.delegate,
|
|
||||||
],
|
|
||||||
localeResolutionCallback: (locale, supportedLocales) {
|
|
||||||
if (!supportedLocales.contains(locale)) {
|
|
||||||
int idx = appSupportedLocales.indexWhere(
|
|
||||||
(element) => element.languageCode == locale!.languageCode);
|
|
||||||
if (idx != -1) {
|
|
||||||
locale = appSupportedLocales[idx];
|
|
||||||
} else {
|
|
||||||
locale = const Locale('zh', 'CN');
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// print("localelocalelocalelocalelocale locale:${locale} locale.languageCode:${locale.languageCode} locale.countryCode:${locale.countryCode} supportedLocales:${supportedLocales}");
|
|
||||||
AppManager()
|
|
||||||
.setLanCode(code: '${locale!.languageCode}_${locale.countryCode}');
|
|
||||||
return locale;
|
|
||||||
},
|
|
||||||
// locale: StoreService.to.getLanguageCode().isNotEmpty ? appDept.deptSupportedLocales.where((element) => element.languageCode == StoreService.to.getLanguageCode()).first : Get.deviceLocale,
|
|
||||||
locale: Get.deviceLocale,
|
|
||||||
fallbackLocale: const Locale('zh', 'CN'),
|
|
||||||
theme: ThemeData(
|
|
||||||
scaffoldBackgroundColor: const Color(0xFFF6F6F6),
|
|
||||||
backgroundColor: const Color(0xFFF6F6F6),
|
|
||||||
primaryColor: const Color(0xFFFFFFFF),
|
|
||||||
textTheme: TextTheme(
|
|
||||||
//用在非Material组件上的文字显示,
|
|
||||||
bodyText1:
|
|
||||||
TextStyle(fontSize: 28.sp, color: const Color(0xff2E2B2B)),
|
|
||||||
//Material组件上的文字显示
|
|
||||||
bodyText2:
|
|
||||||
TextStyle(fontSize: 28.sp, color: const Color(0xff2E2B2B)),
|
|
||||||
button: TextStyle(fontSize: 28.sp)),
|
|
||||||
iconTheme: IconThemeData(size: 28.sp, color: const Color(0xff2E2B2B)),
|
|
||||||
appBarTheme: AppBarTheme(
|
|
||||||
backgroundColor: const Color(0xFFFFFFFF),
|
|
||||||
elevation: 0,
|
|
||||||
centerTitle: true,
|
|
||||||
iconTheme: IconThemeData(color: const Color(0xff333333), size: 36.sp),
|
|
||||||
titleTextStyle: TextStyle(
|
|
||||||
color: const Color(0xff333333),
|
|
||||||
fontWeight: FontWeight.w400,
|
|
||||||
fontSize: 36.sp),
|
|
||||||
),
|
|
||||||
splashColor: Colors.transparent, // 点击时的高亮效果设置为透明
|
|
||||||
highlightColor: Colors.transparent,
|
|
||||||
),
|
|
||||||
debugShowCheckedModeBanner: false,
|
|
||||||
getPages: AppRouters.routePages,
|
|
||||||
builder: EasyLoading.init(),
|
|
||||||
initialBinding: AppBindings(),
|
|
||||||
initialRoute: '/');
|
|
||||||
|
|
||||||
@override
|
|
||||||
void initState() {
|
|
||||||
super.initState();
|
|
||||||
WidgetsBinding.instance.addObserver(this);
|
|
||||||
|
|
||||||
openBlueScan();
|
|
||||||
|
|
||||||
initAliyunPush();
|
|
||||||
}
|
|
||||||
|
|
||||||
//初始化阿里云推送
|
|
||||||
void initAliyunPush() {
|
|
||||||
final aliyunPush = AliyunPush();
|
|
||||||
XSAliyunPushProvider().init(aliyunPush);
|
|
||||||
XSAliyunPushProvider().initAliyunPush();
|
|
||||||
|
|
||||||
if (Platform.isAndroid) {
|
|
||||||
XSAliyunPushProvider().initAliyunThirdPush();
|
|
||||||
}
|
|
||||||
|
|
||||||
//暂使用DeviceID推送
|
|
||||||
aliyunPush.getDeviceId().then((deviceId) async {
|
|
||||||
// print('得到的DeviceId$deviceId');
|
|
||||||
final data = await Storage.getString(saveUserLoginData);
|
|
||||||
if (data!.isNotEmpty && deviceId.isNotEmpty) {
|
|
||||||
XSAliyunPushProvider()
|
|
||||||
.pushBindDeviceID(deviceId, Platform.isAndroid ? 10 : 20);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
@override
|
|
||||||
void dispose() {
|
|
||||||
WidgetsBinding.instance.removeObserver(this);
|
|
||||||
super.dispose();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// 设置国际化信息
|
// 设置国际化信息
|
||||||
Future _initTranslation() async => TranslationLoader.loadTranslation(
|
Future _initTranslation() async => TranslationLoader.loadTranslation(
|
||||||
zhSource: "images/lan/lan_zh.json",
|
zhSource: "images/lan/lan_zh.json",
|
||||||
enSource: "images/lan/lan_en.json",
|
enSource: "images/lan/lan_en.json",
|
||||||
keySource: "images/lan/lan_keys.json",
|
keySource: "images/lan/lan_keys.json",
|
||||||
);
|
);
|
||||||
|
|
||||||
// 设置包名服务设备信息
|
// 设置包名服务设备信息
|
||||||
Future _setCommonServices() async {
|
Future _setCommonServices() async {
|
||||||
@ -167,43 +39,3 @@ Future _setCommonServices() async {
|
|||||||
await Get.putAsync(() => DeviceInfoService().init());
|
await Get.putAsync(() => DeviceInfoService().init());
|
||||||
// Get.log(PlatformInfoService.to.info.version);
|
// Get.log(PlatformInfoService.to.info.version);
|
||||||
}
|
}
|
||||||
|
|
||||||
void openBlueScan() {
|
|
||||||
if (Platform.isIOS) {
|
|
||||||
print("有蓝牙权限开始扫描");
|
|
||||||
// startScanAction();
|
|
||||||
} else {
|
|
||||||
getMicrophonePermission().then((value) {
|
|
||||||
if (value) {
|
|
||||||
// 有权限
|
|
||||||
print("有蓝牙权限开始扫描");
|
|
||||||
// startScanAction();
|
|
||||||
} else {
|
|
||||||
//没有权限
|
|
||||||
openAppSettings(); //打开app系统设置
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// void startScanAction() {
|
|
||||||
// BlueManage().startScan();
|
|
||||||
// }
|
|
||||||
|
|
||||||
///请求蓝牙权限
|
|
||||||
Future<bool> getMicrophonePermission() async {
|
|
||||||
// You can request multiple permissions at once.
|
|
||||||
Map<Permission, PermissionStatus> statuses = await [
|
|
||||||
Permission.bluetoothScan,
|
|
||||||
Permission.bluetoothConnect,
|
|
||||||
Permission.location,
|
|
||||||
].request();
|
|
||||||
|
|
||||||
//granted 通过,denied 被拒绝,permanentlyDenied 拒绝且不在提示
|
|
||||||
if (statuses[Permission.bluetoothScan]!.isGranted &&
|
|
||||||
statuses[Permission.bluetoothConnect]!.isGranted &&
|
|
||||||
statuses[Permission.location]!.isGranted) {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|||||||
@ -271,9 +271,9 @@ class DoorLockLogLogic extends BaseGetXController {
|
|||||||
super.onClose();
|
super.onClose();
|
||||||
|
|
||||||
// 获取是否是演示模式 演示模式不获取接口
|
// 获取是否是演示模式 演示模式不获取接口
|
||||||
var isDemoMode = await Storage.getBool(ifIsDemoModeOrNot);
|
// var isDemoMode = await Storage.getBool(ifIsDemoModeOrNot);
|
||||||
if (isDemoMode == false) {
|
// if (isDemoMode == false) {
|
||||||
_replySubscription.cancel();
|
// _replySubscription.cancel();
|
||||||
}
|
// }
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -1,8 +1,10 @@
|
|||||||
import 'package:flutter/material.dart';
|
import 'package:flutter/material.dart';
|
||||||
import 'package:flutter_advanced_calendar/flutter_advanced_calendar.dart';
|
|
||||||
import 'package:flutter_screenutil/flutter_screenutil.dart';
|
import 'package:flutter_screenutil/flutter_screenutil.dart';
|
||||||
import 'package:get/get.dart';
|
import 'package:get/get.dart';
|
||||||
|
import 'package:star_lock/appRouters.dart';
|
||||||
import 'package:star_lock/main/lockDetail/doorLockLog/doorLockLog_logic.dart';
|
import 'package:star_lock/main/lockDetail/doorLockLog/doorLockLog_logic.dart';
|
||||||
|
import 'package:star_lock/tools/advancedCalendar/src/widget.dart';
|
||||||
|
import 'package:star_lock/tools/menuItem/xsDropDownWidget.dart';
|
||||||
import 'package:timelines/timelines.dart';
|
import 'package:timelines/timelines.dart';
|
||||||
|
|
||||||
import '../../../app_settings/app_colors.dart';
|
import '../../../app_settings/app_colors.dart';
|
||||||
@ -64,10 +66,17 @@ class _DoorLockLogPageState extends State<DoorLockLogPage> {
|
|||||||
endIndent: 30.w,
|
endIndent: 30.w,
|
||||||
),
|
),
|
||||||
eventDropDownWidget(),
|
eventDropDownWidget(),
|
||||||
SizedBox(
|
Expanded(child: timeLineView())
|
||||||
height: 20.h,
|
// Expanded(
|
||||||
),
|
// // 添加 Expanded 来让 ListView 占据剩余的空间
|
||||||
Expanded(child: timeLineView()),
|
// child: ListView.builder(
|
||||||
|
// itemBuilder: (context, index) {
|
||||||
|
// // 返回你想要在 ListView 中显示的小部件
|
||||||
|
// return timeLineView();
|
||||||
|
// },
|
||||||
|
// itemCount: 5, // 替换成你的列表项数量
|
||||||
|
// ),
|
||||||
|
// ),
|
||||||
],
|
],
|
||||||
),
|
),
|
||||||
);
|
);
|
||||||
@ -115,41 +124,24 @@ class _DoorLockLogPageState extends State<DoorLockLogPage> {
|
|||||||
|
|
||||||
//事件下拉框组件
|
//事件下拉框组件
|
||||||
Widget eventDropDownWidget() {
|
Widget eventDropDownWidget() {
|
||||||
return Row(children: [
|
return Container(
|
||||||
SizedBox(
|
margin: EdgeInsets.only(top: 20.h, left: 30.w, bottom: 20.h),
|
||||||
width: 50.w,
|
child: Row(
|
||||||
|
mainAxisAlignment: MainAxisAlignment.start,
|
||||||
|
children: [
|
||||||
|
Obx(() => XSDropDownWidget(
|
||||||
|
items: state.getDropDownItemList,
|
||||||
|
value: state.dropdownValue.value,
|
||||||
|
valueChanged: (value) {})),
|
||||||
|
],
|
||||||
),
|
),
|
||||||
Obx(() => DropdownButton<String>(
|
);
|
||||||
value: state.dropdownValue.value,
|
|
||||||
icon: const Icon(Icons.arrow_drop_down),
|
|
||||||
iconSize: 40,
|
|
||||||
// elevation: 12,
|
|
||||||
style: TextStyle(
|
|
||||||
fontSize: 26.sp,
|
|
||||||
color: Colors.black,
|
|
||||||
fontWeight: FontWeight.w600),
|
|
||||||
iconEnabledColor: Colors.grey,
|
|
||||||
underline: Container(
|
|
||||||
height: 0,
|
|
||||||
),
|
|
||||||
onChanged: (newValue) {
|
|
||||||
state.dropdownValue.value = newValue!;
|
|
||||||
},
|
|
||||||
items: state.dropDownItemList.obs
|
|
||||||
.map<DropdownMenuItem<String>>((item) {
|
|
||||||
return DropdownMenuItem<String>(
|
|
||||||
value: item,
|
|
||||||
child: Text(item),
|
|
||||||
);
|
|
||||||
}).toList(),
|
|
||||||
))
|
|
||||||
]);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//时间轴组件
|
//时间轴组件
|
||||||
Widget timeLineView() {
|
Widget timeLineView() {
|
||||||
return Container(
|
return Container(
|
||||||
margin: EdgeInsets.only(left: 20.w, right: 20.w, bottom: 20.h),
|
margin: EdgeInsets.only(left: 20.w, right: 20.w, bottom: 20.h, top: 20.h),
|
||||||
//给contain设置一个10像素的圆角
|
//给contain设置一个10像素的圆角
|
||||||
decoration: BoxDecoration(
|
decoration: BoxDecoration(
|
||||||
color: Colors.white, borderRadius: BorderRadius.circular(16.w)),
|
color: Colors.white, borderRadius: BorderRadius.circular(16.w)),
|
||||||
@ -168,11 +160,31 @@ class _DoorLockLogPageState extends State<DoorLockLogPage> {
|
|||||||
color: Colors.black,
|
color: Colors.black,
|
||||||
fontSize: 24.sp,
|
fontSize: 24.sp,
|
||||||
fontWeight: FontWeight.w600)),
|
fontWeight: FontWeight.w600)),
|
||||||
Image(
|
GestureDetector(
|
||||||
image: const AssetImage(
|
onTap: () {
|
||||||
'images/main/icon_lockDetail_monitoringvoiceFrist.png'),
|
Get.toNamed(Routers.videoLogDetailPage);
|
||||||
width: 260.w,
|
},
|
||||||
height: 260.h,
|
child: Stack(
|
||||||
|
children: [
|
||||||
|
Image(
|
||||||
|
image: const AssetImage(
|
||||||
|
'images/main/icon_lockDetail_monitoringvoiceFrist.png'),
|
||||||
|
width: 260.w,
|
||||||
|
height: 260.h,
|
||||||
|
),
|
||||||
|
//在图片上添加一个三角视频图标
|
||||||
|
Positioned(
|
||||||
|
top: 200.h,
|
||||||
|
left: 10.w,
|
||||||
|
child: Image(
|
||||||
|
image: const AssetImage(
|
||||||
|
'images/main/icon_lockLog_play.png'),
|
||||||
|
width: 24.w,
|
||||||
|
height: 20.w,
|
||||||
|
),
|
||||||
|
),
|
||||||
|
],
|
||||||
|
),
|
||||||
),
|
),
|
||||||
],
|
],
|
||||||
),
|
),
|
||||||
|
|||||||
@ -1,5 +1,7 @@
|
|||||||
import 'package:flutter_advanced_calendar/flutter_advanced_calendar.dart';
|
import 'package:flutter/cupertino.dart';
|
||||||
import 'package:get/get.dart';
|
import 'package:get/get.dart';
|
||||||
|
import 'package:star_lock/tools/advancedCalendar/src/controller.dart';
|
||||||
|
import 'package:star_lock/tools/menuItem/dropDownItem.dart';
|
||||||
|
|
||||||
import '../../lockMian/entity/lockListInfo_entity.dart';
|
import '../../lockMian/entity/lockListInfo_entity.dart';
|
||||||
import '../electronicKey/electronicKeyDetail/keyOperationRecordEntity.dart';
|
import '../electronicKey/electronicKeyDetail/keyOperationRecordEntity.dart';
|
||||||
@ -14,8 +16,14 @@ class DoorLockLogState {
|
|||||||
DateTime(2024, 10, 10),
|
DateTime(2024, 10, 10),
|
||||||
];
|
];
|
||||||
var dropdownValue = '全部事件'.obs;
|
var dropdownValue = '全部事件'.obs;
|
||||||
final List dropDownItemList =
|
List<DropDownItem> getDropDownItemList = [
|
||||||
['全部事件', '门锁异常', '有人出现', '有人按门铃', '一次性密码开门'].obs;
|
DropDownItem(itemTitle: "全部事件", itemValue: '0', isCheked: false),
|
||||||
|
DropDownItem(itemTitle: "开锁事件", itemValue: '1', isCheked: false),
|
||||||
|
DropDownItem(itemTitle: "异常事件", itemValue: '2', isCheked: false),
|
||||||
|
DropDownItem(itemTitle: "门锁事件", itemValue: '3', isCheked: false),
|
||||||
|
DropDownItem(itemTitle: "视频事件", itemValue: '4', isCheked: false),
|
||||||
|
];
|
||||||
|
|
||||||
var currentStep = 0.obs;
|
var currentStep = 0.obs;
|
||||||
|
|
||||||
DoorLockLogState() {
|
DoorLockLogState() {
|
||||||
|
|||||||
8
star_lock/lib/main_dev.dart
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
import 'flavors.dart';
|
||||||
|
|
||||||
|
import 'main.dart' as runner;
|
||||||
|
|
||||||
|
Future<void> main() async {
|
||||||
|
F.appFlavor = Flavor.dev;
|
||||||
|
await runner.main();
|
||||||
|
}
|
||||||
8
star_lock/lib/main_pre.dart
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
import 'flavors.dart';
|
||||||
|
|
||||||
|
import 'main.dart' as runner;
|
||||||
|
|
||||||
|
Future<void> main() async {
|
||||||
|
F.appFlavor = Flavor.pre;
|
||||||
|
await runner.main();
|
||||||
|
}
|
||||||
8
star_lock/lib/main_sky.dart
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
import 'flavors.dart';
|
||||||
|
|
||||||
|
import 'main.dart' as runner;
|
||||||
|
|
||||||
|
Future<void> main() async {
|
||||||
|
F.appFlavor = Flavor.sky;
|
||||||
|
await runner.main();
|
||||||
|
}
|
||||||
8
star_lock/lib/main_xhj.dart
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
import 'flavors.dart';
|
||||||
|
|
||||||
|
import 'main.dart' as runner;
|
||||||
|
|
||||||
|
Future<void> main() async {
|
||||||
|
F.appFlavor = Flavor.xhj;
|
||||||
|
await runner.main();
|
||||||
|
}
|
||||||
@ -5,6 +5,7 @@ import 'package:star_lock/appRouters.dart';
|
|||||||
import 'package:star_lock/common/XSConstantMacro/XSConstantMacro.dart';
|
import 'package:star_lock/common/XSConstantMacro/XSConstantMacro.dart';
|
||||||
|
|
||||||
import '../../app_settings/app_colors.dart';
|
import '../../app_settings/app_colors.dart';
|
||||||
|
import '../../flavors.dart';
|
||||||
import '../../tools/commonItem.dart';
|
import '../../tools/commonItem.dart';
|
||||||
import '../../tools/titleAppBar.dart';
|
import '../../tools/titleAppBar.dart';
|
||||||
import '../../translations/trans_lib.dart';
|
import '../../translations/trans_lib.dart';
|
||||||
@ -38,12 +39,12 @@ class _AboutPageState extends State<AboutPage> {
|
|||||||
),
|
),
|
||||||
SizedBox(height: 20.h),
|
SizedBox(height: 20.h),
|
||||||
Text(
|
Text(
|
||||||
"星锁 1.0.0.09(preRelease-20240126-1)",
|
"${F.title} 1.0.0.09(preRelease-20240126-1)",
|
||||||
style: TextStyle(fontSize: 24.sp, color: AppColors.blackColor),
|
style: TextStyle(fontSize: 24.sp, color: AppColors.blackColor),
|
||||||
),
|
),
|
||||||
SizedBox(height: 20.h),
|
SizedBox(height: 20.h),
|
||||||
Text(
|
Text(
|
||||||
Api.baseAddress,
|
F.apiPrefix,
|
||||||
style: TextStyle(fontSize: 24.sp, color: AppColors.blackColor),
|
style: TextStyle(fontSize: 24.sp, color: AppColors.blackColor),
|
||||||
),
|
),
|
||||||
SizedBox(
|
SizedBox(
|
||||||
|
|||||||
@ -1,11 +1,4 @@
|
|||||||
abstract class Api {
|
abstract class Api {
|
||||||
// static String baseAddress = "https://pre.lock.star-lock.cn"; //预发布环境
|
|
||||||
static String baseAddress = "https://dev.lock.star-lock.cn"; //联调环境
|
|
||||||
// static String baseAddress = "http://192.168.1.15:8022"; //谢总本地
|
|
||||||
// static String baseAddress = "https://ge.lock.star-lock.cn"; //葛工开发环境地址
|
|
||||||
|
|
||||||
final String baseUrl = "$baseAddress/api";
|
|
||||||
|
|
||||||
// 登录注册
|
// 登录注册
|
||||||
final String getVerificationCodeUrl = '/user/sendValidationCode';
|
final String getVerificationCodeUrl = '/user/sendValidationCode';
|
||||||
final String registerUrl = '/user/register';
|
final String registerUrl = '/user/register';
|
||||||
|
|||||||
@ -2,6 +2,7 @@ import 'package:flutter_easyloading/flutter_easyloading.dart';
|
|||||||
|
|
||||||
import 'package:get/get.dart';
|
import 'package:get/get.dart';
|
||||||
import '../appRouters.dart';
|
import '../appRouters.dart';
|
||||||
|
import '../flavors.dart';
|
||||||
import 'api.dart';
|
import 'api.dart';
|
||||||
import 'request_interceptor.dart';
|
import 'request_interceptor.dart';
|
||||||
import 'request_interceptor_log.dart';
|
import 'request_interceptor_log.dart';
|
||||||
@ -11,7 +12,7 @@ import 'response_interceptor_log.dart';
|
|||||||
class BaseProvider extends GetConnect with Api {
|
class BaseProvider extends GetConnect with Api {
|
||||||
@override
|
@override
|
||||||
void onInit() {
|
void onInit() {
|
||||||
httpClient.baseUrl = baseUrl;
|
httpClient.baseUrl = '${F.apiPrefix}/api';
|
||||||
httpClient.addRequestModifier(requestInterceptor);
|
httpClient.addRequestModifier(requestInterceptor);
|
||||||
httpClient.addResponseModifier(responseInterceptor);
|
httpClient.addResponseModifier(responseInterceptor);
|
||||||
httpClient.addRequestModifier(requestLogInterceptor);
|
httpClient.addRequestModifier(requestLogInterceptor);
|
||||||
|
|||||||
@ -0,0 +1,4 @@
|
|||||||
|
library flutter_advanced_calendar;
|
||||||
|
|
||||||
|
export 'src/controller.dart';
|
||||||
|
export 'src/widget.dart';
|
||||||
15
star_lock/lib/tools/advancedCalendar/src/controller.dart
Normal file
@ -0,0 +1,15 @@
|
|||||||
|
import 'package:flutter/widgets.dart';
|
||||||
|
|
||||||
|
import 'datetime_util.dart';
|
||||||
|
|
||||||
|
/// Advanced Calendar controller that manage selection date state.
|
||||||
|
class AdvancedCalendarController extends ValueNotifier<DateTime> {
|
||||||
|
/// Generates controller with custom date selected.
|
||||||
|
AdvancedCalendarController(DateTime value) : super(value);
|
||||||
|
|
||||||
|
/// Generates controller with today date selected.
|
||||||
|
AdvancedCalendarController.today() : this(DateTime.now().toZeroTime());
|
||||||
|
|
||||||
|
@override
|
||||||
|
set value(DateTime newValue) => super.value = newValue.toZeroTime();
|
||||||
|
}
|
||||||
94
star_lock/lib/tools/advancedCalendar/src/date_box.dart
Normal file
@ -0,0 +1,94 @@
|
|||||||
|
part of 'widget.dart';
|
||||||
|
|
||||||
|
/// Unit of calendar.
|
||||||
|
class DateBox extends StatelessWidget {
|
||||||
|
const DateBox({
|
||||||
|
Key? key,
|
||||||
|
required this.child,
|
||||||
|
this.color,
|
||||||
|
this.width = 24.0,
|
||||||
|
this.height = 24.0,
|
||||||
|
this.borderRadius = const BorderRadius.all(Radius.circular(8.0)),
|
||||||
|
this.onPressed,
|
||||||
|
this.showDot = false,
|
||||||
|
this.isSelected = false,
|
||||||
|
this.isToday = false,
|
||||||
|
this.hasEvent = false,
|
||||||
|
}) : super(key: key);
|
||||||
|
|
||||||
|
/// Child widget.
|
||||||
|
final Widget child;
|
||||||
|
|
||||||
|
/// Background color.
|
||||||
|
final Color? color;
|
||||||
|
|
||||||
|
/// Widget width.
|
||||||
|
final double width;
|
||||||
|
|
||||||
|
/// Widget height.
|
||||||
|
final double height;
|
||||||
|
|
||||||
|
/// Container border radius.
|
||||||
|
final BorderRadius borderRadius;
|
||||||
|
|
||||||
|
/// Pressed callback function.
|
||||||
|
final VoidCallback? onPressed;
|
||||||
|
|
||||||
|
/// Show DateBox event in container.
|
||||||
|
final bool showDot;
|
||||||
|
|
||||||
|
/// DateBox is today.
|
||||||
|
final bool isToday;
|
||||||
|
|
||||||
|
/// DateBox selection.
|
||||||
|
final bool isSelected;
|
||||||
|
|
||||||
|
/// Show event in DateBox.
|
||||||
|
final bool hasEvent;
|
||||||
|
|
||||||
|
@override
|
||||||
|
Widget build(BuildContext context) {
|
||||||
|
final theme = Theme.of(context);
|
||||||
|
return UnconstrainedBox(
|
||||||
|
alignment: Alignment.center,
|
||||||
|
child: InkResponse(
|
||||||
|
onTap: onPressed,
|
||||||
|
radius: 16.0,
|
||||||
|
borderRadius: borderRadius,
|
||||||
|
highlightShape: BoxShape.rectangle,
|
||||||
|
child: AnimatedContainer(
|
||||||
|
duration: const Duration(milliseconds: 150),
|
||||||
|
width: width,
|
||||||
|
height: height,
|
||||||
|
alignment: Alignment.center,
|
||||||
|
decoration: BoxDecoration(
|
||||||
|
color: isSelected
|
||||||
|
? theme.primaryColor
|
||||||
|
: isToday
|
||||||
|
? theme.highlightColor
|
||||||
|
: null,
|
||||||
|
borderRadius: borderRadius,
|
||||||
|
),
|
||||||
|
child: Column(
|
||||||
|
mainAxisAlignment: MainAxisAlignment.center,
|
||||||
|
children: [
|
||||||
|
child,
|
||||||
|
if (showDot && hasEvent)
|
||||||
|
Container(
|
||||||
|
margin: const EdgeInsets.all(2.0),
|
||||||
|
height: 4,
|
||||||
|
width: 4,
|
||||||
|
decoration: BoxDecoration(
|
||||||
|
shape: BoxShape.circle,
|
||||||
|
color: isSelected
|
||||||
|
? theme.colorScheme.onPrimary
|
||||||
|
: theme.colorScheme.secondary,
|
||||||
|
),
|
||||||
|
),
|
||||||
|
],
|
||||||
|
),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
56
star_lock/lib/tools/advancedCalendar/src/datetime_util.dart
Normal file
@ -0,0 +1,56 @@
|
|||||||
|
extension DateTimeUtil on DateTime {
|
||||||
|
/// Generate a new DateTime instance with a zero time.
|
||||||
|
DateTime toZeroTime() => DateTime.utc(year, month, day, 12);
|
||||||
|
|
||||||
|
int findWeekIndex(List<DateTime> dates) {
|
||||||
|
return dates.indexWhere(isAtSameMomentAs) ~/ 7;
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Calculates first week date (Sunday) from this date.
|
||||||
|
DateTime firstDayOfWeek({int? startWeekDay}) {
|
||||||
|
final utcDate = DateTime.utc(year, month, day, 12);
|
||||||
|
if (startWeekDay != null && startWeekDay < 7) {
|
||||||
|
return utcDate.subtract(Duration(days: utcDate.weekday - startWeekDay));
|
||||||
|
}
|
||||||
|
return utcDate.subtract(Duration(days: utcDate.weekday % 7));
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Generates 7 dates according to this date.
|
||||||
|
/// (Supposed that this date is result of [firstDayOfWeek])
|
||||||
|
List<DateTime> weekDates() {
|
||||||
|
return List.generate(
|
||||||
|
7,
|
||||||
|
(index) => add(Duration(days: index)),
|
||||||
|
growable: false,
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Generates list of list with [DateTime]
|
||||||
|
/// according to [date] and [weeksAmount].
|
||||||
|
/// gives the beginning of the day of the week [startWeekDay]
|
||||||
|
List<List<DateTime>> generateWeeks(int weeksAmount, {int? startWeekDay}) {
|
||||||
|
final firstViewDate = firstDayOfWeek(startWeekDay: startWeekDay).subtract(
|
||||||
|
Duration(
|
||||||
|
days: (weeksAmount ~/ 2) * 7,
|
||||||
|
),
|
||||||
|
);
|
||||||
|
|
||||||
|
return List.generate(
|
||||||
|
weeksAmount,
|
||||||
|
(weekIndex) {
|
||||||
|
final firstDateOfNextWeek = firstViewDate.add(
|
||||||
|
Duration(
|
||||||
|
days: weekIndex * 7,
|
||||||
|
),
|
||||||
|
);
|
||||||
|
|
||||||
|
return firstDateOfNextWeek.weekDates();
|
||||||
|
},
|
||||||
|
growable: false,
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
bool isSameDate(DateTime other) {
|
||||||
|
return year == other.year && month == other.month && day == other.day;
|
||||||
|
}
|
||||||
|
}
|
||||||
39
star_lock/lib/tools/advancedCalendar/src/handlebar.dart
Normal file
@ -0,0 +1,39 @@
|
|||||||
|
part of 'widget.dart';
|
||||||
|
|
||||||
|
class HandleBar extends StatelessWidget {
|
||||||
|
const HandleBar({
|
||||||
|
Key? key,
|
||||||
|
this.decoration,
|
||||||
|
this.margin = const EdgeInsets.only(
|
||||||
|
top: 8.0,
|
||||||
|
),
|
||||||
|
this.onPressed,
|
||||||
|
}) : super(key: key);
|
||||||
|
|
||||||
|
final BoxDecoration? decoration;
|
||||||
|
final EdgeInsetsGeometry margin;
|
||||||
|
final VoidCallback? onPressed;
|
||||||
|
|
||||||
|
@override
|
||||||
|
Widget build(BuildContext context) {
|
||||||
|
return GestureDetector(
|
||||||
|
onTap: onPressed,
|
||||||
|
behavior: HitTestBehavior.translucent,
|
||||||
|
child: Container(
|
||||||
|
margin: margin,
|
||||||
|
alignment: Alignment.center,
|
||||||
|
child: FractionallySizedBox(
|
||||||
|
widthFactor: 0.1,
|
||||||
|
child: Container(
|
||||||
|
height: 4.0,
|
||||||
|
decoration: decoration ??
|
||||||
|
BoxDecoration(
|
||||||
|
color: Theme.of(context).dividerColor,
|
||||||
|
borderRadius: BorderRadius.circular(2.0),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
63
star_lock/lib/tools/advancedCalendar/src/header.dart
Normal file
@ -0,0 +1,63 @@
|
|||||||
|
part of 'widget.dart';
|
||||||
|
|
||||||
|
class Header extends StatelessWidget {
|
||||||
|
const Header({
|
||||||
|
Key? key,
|
||||||
|
required this.monthDate,
|
||||||
|
this.margin = const EdgeInsets.only(
|
||||||
|
left: 16.0,
|
||||||
|
right: 8.0,
|
||||||
|
top: 4.0,
|
||||||
|
bottom: 4.0,
|
||||||
|
),
|
||||||
|
this.onPressed,
|
||||||
|
this.dateStyle,
|
||||||
|
this.todayStyle,
|
||||||
|
}) : super(key: key);
|
||||||
|
|
||||||
|
static final _dateFormatter = DateFormat().add_yMMMM();
|
||||||
|
// static final _dateFormatter = DateFormat('MM月dd日', 'zh_CN');
|
||||||
|
final DateTime monthDate;
|
||||||
|
final EdgeInsetsGeometry margin;
|
||||||
|
final VoidCallback? onPressed;
|
||||||
|
final TextStyle? dateStyle;
|
||||||
|
final TextStyle? todayStyle;
|
||||||
|
|
||||||
|
@override
|
||||||
|
Widget build(BuildContext context) {
|
||||||
|
final theme = Theme.of(context);
|
||||||
|
// initializeDateFormatting('zh_CN', null);
|
||||||
|
|
||||||
|
return Container(
|
||||||
|
margin: margin,
|
||||||
|
child: Row(
|
||||||
|
mainAxisAlignment: MainAxisAlignment.spaceBetween,
|
||||||
|
children: [
|
||||||
|
// Text(
|
||||||
|
// _dateFormatter.format(monthDate),
|
||||||
|
// style: dateStyle ?? theme.textTheme.titleMedium,
|
||||||
|
// ),
|
||||||
|
InkWell(
|
||||||
|
onTap: onPressed,
|
||||||
|
borderRadius: const BorderRadius.all(
|
||||||
|
Radius.circular(4.0),
|
||||||
|
),
|
||||||
|
child: Padding(
|
||||||
|
padding: const EdgeInsets.symmetric(
|
||||||
|
horizontal: 8.0,
|
||||||
|
vertical: 4.0,
|
||||||
|
),
|
||||||
|
child: Text(
|
||||||
|
'今天',
|
||||||
|
style: TextStyle(
|
||||||
|
color: Colors.black,
|
||||||
|
fontSize: 24.sp,
|
||||||
|
fontWeight: FontWeight.w600),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
],
|
||||||
|
),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
62
star_lock/lib/tools/advancedCalendar/src/month_view.dart
Normal file
@ -0,0 +1,62 @@
|
|||||||
|
part of 'widget.dart';
|
||||||
|
|
||||||
|
class MonthView extends StatelessWidget {
|
||||||
|
const MonthView({
|
||||||
|
Key? key,
|
||||||
|
required this.monthView,
|
||||||
|
required this.todayDate,
|
||||||
|
required this.selectedDate,
|
||||||
|
required this.weekLineHeight,
|
||||||
|
required this.weeksAmount,
|
||||||
|
required this.innerDot,
|
||||||
|
this.onChanged,
|
||||||
|
this.events,
|
||||||
|
required this.keepLineSize,
|
||||||
|
this.textStyle,
|
||||||
|
}) : super(key: key);
|
||||||
|
|
||||||
|
final ViewRange monthView;
|
||||||
|
final DateTime? todayDate;
|
||||||
|
final DateTime selectedDate;
|
||||||
|
final double weekLineHeight;
|
||||||
|
final int weeksAmount;
|
||||||
|
final ValueChanged<DateTime>? onChanged;
|
||||||
|
final List<DateTime>? events;
|
||||||
|
final bool innerDot;
|
||||||
|
final bool keepLineSize;
|
||||||
|
final TextStyle? textStyle;
|
||||||
|
|
||||||
|
@override
|
||||||
|
Widget build(BuildContext context) {
|
||||||
|
final index = selectedDate.findWeekIndex(monthView.dates);
|
||||||
|
final offset = index / (weeksAmount - 1) * 2 - 1.0;
|
||||||
|
|
||||||
|
return OverflowBox(
|
||||||
|
alignment: Alignment(0, offset),
|
||||||
|
minHeight: weekLineHeight,
|
||||||
|
maxHeight: weekLineHeight * weeksAmount,
|
||||||
|
child: Column(
|
||||||
|
mainAxisSize: MainAxisSize.min,
|
||||||
|
children: List<Widget>.generate(
|
||||||
|
6,
|
||||||
|
(weekIndex) {
|
||||||
|
final weekStart = weekIndex * 7;
|
||||||
|
|
||||||
|
return WeekView(
|
||||||
|
innerDot: innerDot,
|
||||||
|
dates: monthView.dates.sublist(weekStart, weekStart + 7),
|
||||||
|
selectedDate: selectedDate,
|
||||||
|
highlightMonth: monthView.firstDay.month,
|
||||||
|
lineHeight: weekLineHeight,
|
||||||
|
onChanged: onChanged,
|
||||||
|
events: events,
|
||||||
|
keepLineSize: keepLineSize,
|
||||||
|
textStyle: textStyle,
|
||||||
|
);
|
||||||
|
},
|
||||||
|
growable: false,
|
||||||
|
),
|
||||||
|
),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
@ -0,0 +1,40 @@
|
|||||||
|
part of 'widget.dart';
|
||||||
|
|
||||||
|
class ViewRange {
|
||||||
|
const ViewRange._(this.firstDay, this.dates);
|
||||||
|
|
||||||
|
/// Creates custom filled [ViewRange] instance.
|
||||||
|
const ViewRange.custom(
|
||||||
|
DateTime firstDay,
|
||||||
|
List<DateTime> dates,
|
||||||
|
) : this._(firstDay, dates);
|
||||||
|
|
||||||
|
/// Generates [ViewRange] instance based on [date],
|
||||||
|
/// number of [month] and [weeksAmount].
|
||||||
|
/// gives the beginning of the day of the week [startWeekDay]
|
||||||
|
factory ViewRange.generateDates(
|
||||||
|
DateTime date,
|
||||||
|
int month,
|
||||||
|
int weeksAmount, {
|
||||||
|
int? startWeekDay,
|
||||||
|
}) {
|
||||||
|
final firstMonthDate = DateTime.utc(date.year, month, 1);
|
||||||
|
final firstViewDate =
|
||||||
|
firstMonthDate.firstDayOfWeek(startWeekDay: startWeekDay);
|
||||||
|
|
||||||
|
return ViewRange._(
|
||||||
|
firstMonthDate,
|
||||||
|
List.generate(
|
||||||
|
weeksAmount * 7,
|
||||||
|
(index) => firstViewDate.add(Duration(days: index)),
|
||||||
|
growable: false,
|
||||||
|
),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Month view index.
|
||||||
|
final DateTime firstDay;
|
||||||
|
|
||||||
|
/// Month view dates.
|
||||||
|
final List<DateTime> dates;
|
||||||
|
}
|
||||||
36
star_lock/lib/tools/advancedCalendar/src/week_days.dart
Normal file
@ -0,0 +1,36 @@
|
|||||||
|
part of 'widget.dart';
|
||||||
|
|
||||||
|
/// Week day names line.
|
||||||
|
class WeekDays extends StatelessWidget {
|
||||||
|
const WeekDays({
|
||||||
|
Key? key,
|
||||||
|
this.weekNames = const <String>['日', '一', '二', '三', '四', '五', '六'],
|
||||||
|
this.style,
|
||||||
|
required this.keepLineSize,
|
||||||
|
}) : assert(weekNames.length == 7, '`weekNames` must have length 7'),
|
||||||
|
super(key: key);
|
||||||
|
|
||||||
|
/// Week day names.
|
||||||
|
final List<String> weekNames;
|
||||||
|
|
||||||
|
/// Text style.
|
||||||
|
final TextStyle? style;
|
||||||
|
|
||||||
|
final bool keepLineSize;
|
||||||
|
|
||||||
|
@override
|
||||||
|
Widget build(BuildContext context) {
|
||||||
|
return DefaultTextStyle(
|
||||||
|
style: style!,
|
||||||
|
child: Row(
|
||||||
|
mainAxisSize: MainAxisSize.max,
|
||||||
|
mainAxisAlignment: MainAxisAlignment.spaceAround,
|
||||||
|
children: List.generate(weekNames.length, (index) {
|
||||||
|
return DateBox(
|
||||||
|
child: Text(weekNames[index]),
|
||||||
|
);
|
||||||
|
}),
|
||||||
|
),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
137
star_lock/lib/tools/advancedCalendar/src/week_view.dart
Normal file
@ -0,0 +1,137 @@
|
|||||||
|
part of 'widget.dart';
|
||||||
|
|
||||||
|
class WeekView extends StatelessWidget {
|
||||||
|
WeekView({
|
||||||
|
Key? key,
|
||||||
|
required this.dates,
|
||||||
|
required this.selectedDate,
|
||||||
|
required this.lineHeight,
|
||||||
|
this.highlightMonth,
|
||||||
|
this.onChanged,
|
||||||
|
this.events,
|
||||||
|
required this.innerDot,
|
||||||
|
required this.keepLineSize,
|
||||||
|
this.textStyle,
|
||||||
|
}) : super(key: key);
|
||||||
|
|
||||||
|
final DateTime todayDate = DateTime.now().toZeroTime();
|
||||||
|
final List<DateTime> dates;
|
||||||
|
final double lineHeight;
|
||||||
|
final int? highlightMonth;
|
||||||
|
final DateTime selectedDate;
|
||||||
|
final ValueChanged<DateTime>? onChanged;
|
||||||
|
final List<DateTime>? events;
|
||||||
|
final bool innerDot;
|
||||||
|
final bool keepLineSize;
|
||||||
|
final TextStyle? textStyle;
|
||||||
|
|
||||||
|
@override
|
||||||
|
Widget build(BuildContext context) {
|
||||||
|
final theme = Theme.of(context);
|
||||||
|
return SizedBox(
|
||||||
|
height: lineHeight,
|
||||||
|
child: Row(
|
||||||
|
mainAxisSize: MainAxisSize.max,
|
||||||
|
mainAxisAlignment: MainAxisAlignment.spaceAround,
|
||||||
|
crossAxisAlignment: CrossAxisAlignment.center,
|
||||||
|
children: List<Widget>.generate(
|
||||||
|
7,
|
||||||
|
(dayIndex) {
|
||||||
|
final date = dates[dayIndex];
|
||||||
|
final isToday = date.isAtSameMomentAs(todayDate);
|
||||||
|
final isSelected = date.isAtSameMomentAs(selectedDate);
|
||||||
|
final isHighlight = highlightMonth == date.month;
|
||||||
|
|
||||||
|
final hasEvent =
|
||||||
|
events!.indexWhere((element) => element.isSameDate(date));
|
||||||
|
|
||||||
|
if (keepLineSize) {
|
||||||
|
return InkResponse(
|
||||||
|
onTap: onChanged != null ? () => onChanged!(date) : null,
|
||||||
|
child: Container(
|
||||||
|
height: 36,
|
||||||
|
width: 36,
|
||||||
|
decoration: BoxDecoration(
|
||||||
|
color: isSelected
|
||||||
|
? theme.primaryColor
|
||||||
|
: isToday
|
||||||
|
? theme.highlightColor
|
||||||
|
: null,
|
||||||
|
borderRadius: BorderRadius.circular(18),
|
||||||
|
shape: BoxShape.rectangle,
|
||||||
|
),
|
||||||
|
child: Column(
|
||||||
|
children: [
|
||||||
|
Text(
|
||||||
|
'${date.day}',
|
||||||
|
style: textStyle?.copyWith(
|
||||||
|
color: isSelected || isToday
|
||||||
|
? theme.colorScheme.onPrimary
|
||||||
|
: isHighlight || highlightMonth == null
|
||||||
|
? null
|
||||||
|
: theme.disabledColor,
|
||||||
|
fontWeight:
|
||||||
|
isSelected && textStyle?.fontWeight != null
|
||||||
|
? FontWeight
|
||||||
|
.values[textStyle!.fontWeight!.index + 2]
|
||||||
|
: textStyle?.fontWeight,
|
||||||
|
),
|
||||||
|
),
|
||||||
|
if (!hasEvent.isNegative)
|
||||||
|
Container(
|
||||||
|
height: 4,
|
||||||
|
width: 4,
|
||||||
|
decoration: BoxDecoration(
|
||||||
|
borderRadius: BorderRadius.circular(50),
|
||||||
|
color: isSelected
|
||||||
|
? theme.colorScheme.onPrimary
|
||||||
|
: theme.colorScheme.secondary,
|
||||||
|
),
|
||||||
|
)
|
||||||
|
],
|
||||||
|
),
|
||||||
|
),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
return Column(
|
||||||
|
mainAxisAlignment: MainAxisAlignment.spaceEvenly,
|
||||||
|
children: [
|
||||||
|
DateBox(
|
||||||
|
width: innerDot ? 32 : 24,
|
||||||
|
height: innerDot ? 32 : 24,
|
||||||
|
showDot: innerDot,
|
||||||
|
onPressed: onChanged != null ? () => onChanged!(date) : null,
|
||||||
|
isSelected: isSelected,
|
||||||
|
isToday: isToday,
|
||||||
|
hasEvent: !hasEvent.isNegative,
|
||||||
|
child: Text(
|
||||||
|
'${date.day}',
|
||||||
|
maxLines: 1,
|
||||||
|
style: TextStyle(
|
||||||
|
color: isSelected || isToday
|
||||||
|
? theme.colorScheme.onPrimary
|
||||||
|
: isHighlight || highlightMonth == null
|
||||||
|
? null
|
||||||
|
: theme.disabledColor,
|
||||||
|
),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
if (!innerDot && !hasEvent.isNegative)
|
||||||
|
Container(
|
||||||
|
height: 6,
|
||||||
|
width: 6,
|
||||||
|
decoration: BoxDecoration(
|
||||||
|
borderRadius: BorderRadius.circular(50),
|
||||||
|
color: theme.primaryColor,
|
||||||
|
),
|
||||||
|
)
|
||||||
|
],
|
||||||
|
);
|
||||||
|
},
|
||||||
|
growable: false,
|
||||||
|
),
|
||||||
|
),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
420
star_lock/lib/tools/advancedCalendar/src/widget.dart
Normal file
@ -0,0 +1,420 @@
|
|||||||
|
import 'package:flutter/material.dart';
|
||||||
|
import 'package:flutter_screenutil/flutter_screenutil.dart';
|
||||||
|
import 'package:intl/date_symbol_data_local.dart';
|
||||||
|
import 'package:intl/intl.dart';
|
||||||
|
|
||||||
|
import 'controller.dart';
|
||||||
|
import 'datetime_util.dart';
|
||||||
|
|
||||||
|
part 'date_box.dart';
|
||||||
|
part 'handlebar.dart';
|
||||||
|
part 'header.dart';
|
||||||
|
part 'month_view.dart';
|
||||||
|
part 'month_view_bean.dart';
|
||||||
|
part 'week_days.dart';
|
||||||
|
part 'week_view.dart';
|
||||||
|
|
||||||
|
/// Advanced Calendar widget.
|
||||||
|
class AdvancedCalendar extends StatefulWidget {
|
||||||
|
const AdvancedCalendar({
|
||||||
|
Key? key,
|
||||||
|
this.controller,
|
||||||
|
this.startWeekDay,
|
||||||
|
this.events,
|
||||||
|
this.weekLineHeight = 32.0,
|
||||||
|
this.preloadMonthViewAmount = 13,
|
||||||
|
this.preloadWeekViewAmount = 21,
|
||||||
|
this.weeksInMonthViewAmount = 6,
|
||||||
|
this.todayStyle,
|
||||||
|
this.headerStyle,
|
||||||
|
this.onHorizontalDrag,
|
||||||
|
this.innerDot = false,
|
||||||
|
this.keepLineSize = false,
|
||||||
|
this.calendarTextStyle,
|
||||||
|
}) : assert(
|
||||||
|
keepLineSize && innerDot ||
|
||||||
|
innerDot && !keepLineSize ||
|
||||||
|
!innerDot && !keepLineSize,
|
||||||
|
'keepLineSize should be used only when innerDot is true',
|
||||||
|
),
|
||||||
|
super(key: key);
|
||||||
|
|
||||||
|
/// Calendar selection date controller.
|
||||||
|
final AdvancedCalendarController? controller;
|
||||||
|
|
||||||
|
/// Executes on horizontal calendar swipe. Allows to load additional dates.
|
||||||
|
final Function(DateTime)? onHorizontalDrag;
|
||||||
|
|
||||||
|
/// Height of week line.
|
||||||
|
final double weekLineHeight;
|
||||||
|
|
||||||
|
/// Amount of months in month view to preload.
|
||||||
|
final int preloadMonthViewAmount;
|
||||||
|
|
||||||
|
/// Amount of weeks in week view to preload.
|
||||||
|
final int preloadWeekViewAmount;
|
||||||
|
|
||||||
|
/// Weeks lines amount in month view.
|
||||||
|
final int weeksInMonthViewAmount;
|
||||||
|
|
||||||
|
/// List of points for the week and month
|
||||||
|
final List<DateTime>? events;
|
||||||
|
|
||||||
|
/// The first day of the week starts[0-6]
|
||||||
|
final int? startWeekDay;
|
||||||
|
|
||||||
|
/// Style of headers date
|
||||||
|
final TextStyle? headerStyle;
|
||||||
|
|
||||||
|
/// Style of Today button
|
||||||
|
final TextStyle? todayStyle;
|
||||||
|
|
||||||
|
/// Show DateBox event in container.
|
||||||
|
final bool innerDot;
|
||||||
|
|
||||||
|
/// Keeps consistent line size for dates
|
||||||
|
/// Can't be used without innerDot
|
||||||
|
final bool keepLineSize;
|
||||||
|
|
||||||
|
/// Text style for dates in calendar
|
||||||
|
final TextStyle? calendarTextStyle;
|
||||||
|
|
||||||
|
@override
|
||||||
|
_AdvancedCalendarState createState() => _AdvancedCalendarState();
|
||||||
|
}
|
||||||
|
|
||||||
|
class _AdvancedCalendarState extends State<AdvancedCalendar>
|
||||||
|
with SingleTickerProviderStateMixin {
|
||||||
|
late ValueNotifier<int> _monthViewCurrentPage;
|
||||||
|
late AnimationController _animationController;
|
||||||
|
late AdvancedCalendarController _controller;
|
||||||
|
late double _animationValue;
|
||||||
|
late List<ViewRange> _monthRangeList;
|
||||||
|
late List<List<DateTime>> _weekRangeList;
|
||||||
|
|
||||||
|
PageController? _monthPageController;
|
||||||
|
PageController? _weekPageController;
|
||||||
|
Offset? _captureOffset;
|
||||||
|
DateTime? _todayDate;
|
||||||
|
List<String>? _weekNames;
|
||||||
|
|
||||||
|
@override
|
||||||
|
void initState() {
|
||||||
|
super.initState();
|
||||||
|
|
||||||
|
final monthPageIndex = widget.preloadMonthViewAmount ~/ 2;
|
||||||
|
|
||||||
|
_monthViewCurrentPage = ValueNotifier(monthPageIndex);
|
||||||
|
|
||||||
|
_monthPageController = PageController(
|
||||||
|
initialPage: monthPageIndex,
|
||||||
|
);
|
||||||
|
|
||||||
|
final weekPageIndex = widget.preloadWeekViewAmount ~/ 2;
|
||||||
|
|
||||||
|
_weekPageController = PageController(
|
||||||
|
initialPage: weekPageIndex,
|
||||||
|
);
|
||||||
|
|
||||||
|
_animationController = AnimationController(
|
||||||
|
vsync: this,
|
||||||
|
duration: const Duration(milliseconds: 300),
|
||||||
|
value: 0,
|
||||||
|
);
|
||||||
|
|
||||||
|
_animationValue = _animationController.value;
|
||||||
|
|
||||||
|
_controller = widget.controller ?? AdvancedCalendarController.today();
|
||||||
|
_todayDate = _controller.value;
|
||||||
|
|
||||||
|
_monthRangeList = List.generate(
|
||||||
|
widget.preloadMonthViewAmount,
|
||||||
|
(index) => ViewRange.generateDates(
|
||||||
|
_todayDate!,
|
||||||
|
_todayDate!.month + (index - _monthPageController!.initialPage),
|
||||||
|
widget.weeksInMonthViewAmount,
|
||||||
|
startWeekDay: widget.startWeekDay,
|
||||||
|
),
|
||||||
|
);
|
||||||
|
|
||||||
|
_weekRangeList = _controller.value.generateWeeks(
|
||||||
|
widget.preloadWeekViewAmount,
|
||||||
|
startWeekDay: widget.startWeekDay,
|
||||||
|
);
|
||||||
|
_controller.addListener(() {
|
||||||
|
_weekRangeList = _controller.value.generateWeeks(
|
||||||
|
widget.preloadWeekViewAmount,
|
||||||
|
startWeekDay: widget.startWeekDay,
|
||||||
|
);
|
||||||
|
_weekPageController!.jumpToPage(widget.preloadWeekViewAmount ~/ 2);
|
||||||
|
});
|
||||||
|
if (widget.startWeekDay != null && widget.startWeekDay! < 7) {
|
||||||
|
final time = _controller.value.subtract(
|
||||||
|
Duration(days: _controller.value.weekday - widget.startWeekDay!),
|
||||||
|
);
|
||||||
|
final list = List<DateTime>.generate(
|
||||||
|
8,
|
||||||
|
(index) => time.add(Duration(days: index * 1)),
|
||||||
|
).toList();
|
||||||
|
// _weekNames = List<String>.generate(7, (index) {
|
||||||
|
// return DateFormat("EEEE").format(list[index]).split('').first;
|
||||||
|
// }
|
||||||
|
// );
|
||||||
|
//by DaisyWu 修改源文件为中文环境下 周一到周日
|
||||||
|
_weekNames = List<String>.generate(7, (index) {
|
||||||
|
String fullWeekName =
|
||||||
|
DateFormat.E('zh_CN').format(list[index]); // 获取星期的完整形式
|
||||||
|
return fullWeekName
|
||||||
|
.substring(fullWeekName.length - 1); // 获取最后一个字符,即星期的简称
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@override
|
||||||
|
Widget build(BuildContext context) {
|
||||||
|
final theme = Theme.of(context);
|
||||||
|
return Material(
|
||||||
|
color: Colors.transparent,
|
||||||
|
child: DefaultTextStyle.merge(
|
||||||
|
style: theme.textTheme.bodyMedium,
|
||||||
|
child: GestureDetector(
|
||||||
|
onVerticalDragStart: (details) {
|
||||||
|
_captureOffset = details.globalPosition;
|
||||||
|
},
|
||||||
|
onVerticalDragUpdate: (details) {
|
||||||
|
final moveOffset = details.globalPosition;
|
||||||
|
final diffY = moveOffset.dy - _captureOffset!.dy;
|
||||||
|
|
||||||
|
_animationController.value =
|
||||||
|
_animationValue + diffY / (widget.weekLineHeight * 5);
|
||||||
|
},
|
||||||
|
onVerticalDragEnd: (details) => _handleFinishDrag(),
|
||||||
|
onVerticalDragCancel: _handleFinishDrag,
|
||||||
|
child: Container(
|
||||||
|
color: Colors.transparent,
|
||||||
|
child: Column(
|
||||||
|
mainAxisSize: MainAxisSize.min,
|
||||||
|
mainAxisAlignment: MainAxisAlignment.start,
|
||||||
|
crossAxisAlignment: CrossAxisAlignment.start,
|
||||||
|
children: [
|
||||||
|
ValueListenableBuilder<int>(
|
||||||
|
valueListenable: _monthViewCurrentPage,
|
||||||
|
builder: (_, value, __) {
|
||||||
|
return Header(
|
||||||
|
monthDate:
|
||||||
|
_monthRangeList[_monthViewCurrentPage.value].firstDay,
|
||||||
|
onPressed: _handleTodayPressed,
|
||||||
|
dateStyle: widget.headerStyle,
|
||||||
|
todayStyle: widget.todayStyle,
|
||||||
|
);
|
||||||
|
},
|
||||||
|
),
|
||||||
|
WeekDays(
|
||||||
|
style: theme.textTheme.bodyLarge?.copyWith(
|
||||||
|
color: Colors.black,
|
||||||
|
),
|
||||||
|
keepLineSize: widget.keepLineSize,
|
||||||
|
weekNames: _weekNames != null
|
||||||
|
? _weekNames!
|
||||||
|
: const <String>['日', '一', '二', '三', '四', '五', '六'],
|
||||||
|
),
|
||||||
|
AnimatedBuilder(
|
||||||
|
animation: _animationController,
|
||||||
|
builder: (_, __) {
|
||||||
|
final height = Tween<double>(
|
||||||
|
begin: widget.weekLineHeight,
|
||||||
|
end:
|
||||||
|
widget.weekLineHeight * widget.weeksInMonthViewAmount,
|
||||||
|
).transform(_animationController.value);
|
||||||
|
return SizedBox(
|
||||||
|
height: height,
|
||||||
|
child: ValueListenableBuilder<DateTime>(
|
||||||
|
valueListenable: _controller,
|
||||||
|
builder: (_, selectedDate, __) {
|
||||||
|
return Stack(
|
||||||
|
alignment: Alignment.center,
|
||||||
|
children: [
|
||||||
|
IgnorePointer(
|
||||||
|
ignoring: _animationController.value == 0.0,
|
||||||
|
child: Opacity(
|
||||||
|
opacity: Tween<double>(
|
||||||
|
begin: 0.0,
|
||||||
|
end: 1.0,
|
||||||
|
).evaluate(_animationController),
|
||||||
|
child: PageView.builder(
|
||||||
|
onPageChanged: (pageIndex) {
|
||||||
|
if (widget.onHorizontalDrag != null) {
|
||||||
|
widget.onHorizontalDrag!(
|
||||||
|
_monthRangeList[pageIndex].firstDay,
|
||||||
|
);
|
||||||
|
}
|
||||||
|
_monthViewCurrentPage.value = pageIndex;
|
||||||
|
},
|
||||||
|
controller: _monthPageController,
|
||||||
|
physics: _animationController.value == 1.0
|
||||||
|
? const AlwaysScrollableScrollPhysics()
|
||||||
|
: const NeverScrollableScrollPhysics(),
|
||||||
|
itemCount: _monthRangeList.length,
|
||||||
|
itemBuilder: (_, pageIndex) {
|
||||||
|
return MonthView(
|
||||||
|
innerDot: widget.innerDot,
|
||||||
|
monthView: _monthRangeList[pageIndex],
|
||||||
|
todayDate: _todayDate,
|
||||||
|
selectedDate: selectedDate,
|
||||||
|
weekLineHeight: widget.weekLineHeight,
|
||||||
|
weeksAmount:
|
||||||
|
widget.weeksInMonthViewAmount,
|
||||||
|
onChanged: _handleDateChanged,
|
||||||
|
events: widget.events,
|
||||||
|
keepLineSize: widget.keepLineSize,
|
||||||
|
textStyle: widget.calendarTextStyle,
|
||||||
|
);
|
||||||
|
},
|
||||||
|
),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
ValueListenableBuilder<int>(
|
||||||
|
valueListenable: _monthViewCurrentPage,
|
||||||
|
builder: (_, pageIndex, __) {
|
||||||
|
final index = selectedDate.findWeekIndex(
|
||||||
|
_monthRangeList[_monthViewCurrentPage.value]
|
||||||
|
.dates,
|
||||||
|
);
|
||||||
|
final offset = index /
|
||||||
|
(widget.weeksInMonthViewAmount - 1) *
|
||||||
|
2 -
|
||||||
|
1.0;
|
||||||
|
return Align(
|
||||||
|
alignment: Alignment(0.0, offset),
|
||||||
|
child: IgnorePointer(
|
||||||
|
ignoring:
|
||||||
|
_animationController.value == 1.0,
|
||||||
|
child: Opacity(
|
||||||
|
opacity: Tween<double>(
|
||||||
|
begin: 1.0,
|
||||||
|
end: 0.0,
|
||||||
|
).evaluate(_animationController),
|
||||||
|
child: SizedBox(
|
||||||
|
height: widget.weekLineHeight,
|
||||||
|
child: PageView.builder(
|
||||||
|
onPageChanged: (indexPage) {
|
||||||
|
final pageIndex =
|
||||||
|
_monthRangeList.indexWhere(
|
||||||
|
(index) =>
|
||||||
|
index.firstDay.month ==
|
||||||
|
_weekRangeList[indexPage]
|
||||||
|
.first
|
||||||
|
.month,
|
||||||
|
);
|
||||||
|
|
||||||
|
if (widget.onHorizontalDrag !=
|
||||||
|
null) {
|
||||||
|
widget.onHorizontalDrag!(
|
||||||
|
_monthRangeList[pageIndex]
|
||||||
|
.firstDay,
|
||||||
|
);
|
||||||
|
}
|
||||||
|
_monthViewCurrentPage.value =
|
||||||
|
pageIndex;
|
||||||
|
},
|
||||||
|
controller: _weekPageController,
|
||||||
|
itemCount: _weekRangeList.length,
|
||||||
|
physics: _closeMonthScroll(),
|
||||||
|
itemBuilder: (context, index) {
|
||||||
|
return WeekView(
|
||||||
|
innerDot: widget.innerDot,
|
||||||
|
dates: _weekRangeList[index],
|
||||||
|
selectedDate: selectedDate,
|
||||||
|
lineHeight:
|
||||||
|
widget.weekLineHeight,
|
||||||
|
onChanged:
|
||||||
|
_handleWeekDateChanged,
|
||||||
|
events: widget.events,
|
||||||
|
keepLineSize:
|
||||||
|
widget.keepLineSize,
|
||||||
|
textStyle:
|
||||||
|
widget.calendarTextStyle,
|
||||||
|
);
|
||||||
|
},
|
||||||
|
),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
);
|
||||||
|
},
|
||||||
|
),
|
||||||
|
],
|
||||||
|
);
|
||||||
|
},
|
||||||
|
),
|
||||||
|
);
|
||||||
|
},
|
||||||
|
),
|
||||||
|
// HandleBar(
|
||||||
|
// onPressed: () async {
|
||||||
|
// await _animationController.forward();
|
||||||
|
// _animationValue = 1.0;
|
||||||
|
// },
|
||||||
|
// ),
|
||||||
|
],
|
||||||
|
),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
@override
|
||||||
|
void dispose() {
|
||||||
|
_animationController.dispose();
|
||||||
|
_monthPageController!.dispose();
|
||||||
|
_monthViewCurrentPage.dispose();
|
||||||
|
|
||||||
|
if (widget.controller == null) {
|
||||||
|
_controller.dispose();
|
||||||
|
}
|
||||||
|
|
||||||
|
super.dispose();
|
||||||
|
}
|
||||||
|
|
||||||
|
void _handleWeekDateChanged(DateTime date) {
|
||||||
|
_handleDateChanged(date);
|
||||||
|
|
||||||
|
_monthViewCurrentPage.value = _monthRangeList
|
||||||
|
.lastIndexWhere((monthRange) => monthRange.dates.contains(date));
|
||||||
|
}
|
||||||
|
|
||||||
|
void _handleDateChanged(DateTime date) {
|
||||||
|
_controller.value = date;
|
||||||
|
}
|
||||||
|
|
||||||
|
void _handleFinishDrag() async {
|
||||||
|
_captureOffset = null;
|
||||||
|
|
||||||
|
if (_animationController.value > 0.5) {
|
||||||
|
await _animationController.forward();
|
||||||
|
_animationValue = 1.0;
|
||||||
|
} else {
|
||||||
|
await _animationController.reverse();
|
||||||
|
_animationValue = 0.0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void _handleTodayPressed() {
|
||||||
|
_controller.value = DateTime.now().toZeroTime();
|
||||||
|
|
||||||
|
_monthPageController!.jumpToPage(widget.preloadMonthViewAmount ~/ 2);
|
||||||
|
_weekPageController!.jumpToPage(widget.preloadWeekViewAmount ~/ 2);
|
||||||
|
}
|
||||||
|
|
||||||
|
ScrollPhysics _closeMonthScroll() {
|
||||||
|
if ((_monthViewCurrentPage.value ==
|
||||||
|
(widget.preloadMonthViewAmount ~/ 2) + 3 ||
|
||||||
|
_monthViewCurrentPage.value ==
|
||||||
|
(widget.preloadMonthViewAmount ~/ 2) - 3)) {
|
||||||
|
return const NeverScrollableScrollPhysics();
|
||||||
|
} else {
|
||||||
|
return const AlwaysScrollableScrollPhysics();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
14
star_lock/lib/tools/menuItem/dropDownItem.dart
Normal file
@ -0,0 +1,14 @@
|
|||||||
|
/// 通用菜单项
|
||||||
|
class DropDownItem {
|
||||||
|
// 显示的文本
|
||||||
|
String itemTitle = '';
|
||||||
|
// 选中的值
|
||||||
|
dynamic itemValue;
|
||||||
|
// 是否选中
|
||||||
|
bool isCheked = false;
|
||||||
|
|
||||||
|
DropDownItem(
|
||||||
|
{required this.itemTitle,
|
||||||
|
required this.itemValue,
|
||||||
|
required this.isCheked});
|
||||||
|
}
|
||||||
161
star_lock/lib/tools/menuItem/xsDropDownWidget.dart
Normal file
@ -0,0 +1,161 @@
|
|||||||
|
import 'package:flutter/material.dart';
|
||||||
|
import 'package:flutter_screenutil/flutter_screenutil.dart';
|
||||||
|
import 'package:star_lock/app_settings/app_colors.dart';
|
||||||
|
import 'package:star_lock/tools/menuItem/dropDownItem.dart';
|
||||||
|
|
||||||
|
/// @author baorant
|
||||||
|
/// @创建时间:2024/4/11
|
||||||
|
/// 下拉菜单按钮组件
|
||||||
|
class XSDropDownWidget extends StatefulWidget {
|
||||||
|
// 显示的菜单项
|
||||||
|
List<DropDownItem> items = [];
|
||||||
|
// 当前选中的值
|
||||||
|
final dynamic value;
|
||||||
|
// 选择框前的标题
|
||||||
|
final String? title;
|
||||||
|
// 提示语
|
||||||
|
final String tooltip;
|
||||||
|
// 选中数据的回调事件
|
||||||
|
final ValueChanged<dynamic>? valueChanged;
|
||||||
|
XSDropDownWidget(
|
||||||
|
{Key? key,
|
||||||
|
required this.items,
|
||||||
|
this.value,
|
||||||
|
this.valueChanged,
|
||||||
|
this.title,
|
||||||
|
this.tooltip = "点击选择"})
|
||||||
|
: super(key: key);
|
||||||
|
|
||||||
|
@override
|
||||||
|
State<XSDropDownWidget> createState() => _XSDropDownWidgetState();
|
||||||
|
}
|
||||||
|
|
||||||
|
class _XSDropDownWidgetState extends State<XSDropDownWidget> {
|
||||||
|
String label = '请选择';
|
||||||
|
// 是否展开下拉按钮
|
||||||
|
bool isExpand = false;
|
||||||
|
// 当前的值
|
||||||
|
dynamic currentValue;
|
||||||
|
|
||||||
|
@override
|
||||||
|
void initState() {
|
||||||
|
currentValue = widget.value;
|
||||||
|
super.initState();
|
||||||
|
}
|
||||||
|
|
||||||
|
/// 根据当前的value处理当前文本显示
|
||||||
|
void initTitle() {
|
||||||
|
if (currentValue != null) {
|
||||||
|
// 有值查值
|
||||||
|
for (DropDownItem item in widget.items) {
|
||||||
|
if (item.itemValue == currentValue) {
|
||||||
|
label = item.itemTitle;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// 没值默认取第一个
|
||||||
|
if (widget.items.isNotEmpty) {
|
||||||
|
label = widget.items[0].itemTitle;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@override
|
||||||
|
Widget build(BuildContext context) {
|
||||||
|
initTitle();
|
||||||
|
return Wrap(
|
||||||
|
children: [
|
||||||
|
if (widget.title != null)
|
||||||
|
Text(widget.title!,
|
||||||
|
style: TextStyle(
|
||||||
|
fontSize: 26.sp,
|
||||||
|
color: Colors.black,
|
||||||
|
fontWeight: FontWeight.w600,
|
||||||
|
)),
|
||||||
|
PopupMenuButton<String>(
|
||||||
|
color: Colors.white,
|
||||||
|
// initialValue: currentValue,
|
||||||
|
tooltip: widget.tooltip,
|
||||||
|
offset: const Offset(0, 30),
|
||||||
|
enableFeedback: true,
|
||||||
|
child: Listener(
|
||||||
|
// 使用listener事件能够继续传递
|
||||||
|
onPointerDown: (event) {
|
||||||
|
setState(() {
|
||||||
|
isExpand = !isExpand;
|
||||||
|
});
|
||||||
|
},
|
||||||
|
child: Wrap(
|
||||||
|
children: [
|
||||||
|
Text(
|
||||||
|
label,
|
||||||
|
style: TextStyle(
|
||||||
|
fontSize: 24.sp,
|
||||||
|
color: Colors.black,
|
||||||
|
fontWeight: FontWeight.w600,
|
||||||
|
),
|
||||||
|
),
|
||||||
|
isExpand
|
||||||
|
? const Icon(Icons.arrow_drop_up)
|
||||||
|
: const Icon(Icons.arrow_drop_down)
|
||||||
|
],
|
||||||
|
),
|
||||||
|
),
|
||||||
|
onSelected: (value) {
|
||||||
|
widget.valueChanged?.call(value);
|
||||||
|
setState(() {
|
||||||
|
currentValue = value;
|
||||||
|
isExpand = !isExpand;
|
||||||
|
});
|
||||||
|
},
|
||||||
|
onCanceled: () {
|
||||||
|
// 取消展开
|
||||||
|
setState(() {
|
||||||
|
isExpand = false;
|
||||||
|
});
|
||||||
|
},
|
||||||
|
itemBuilder: (context) {
|
||||||
|
return widget.items.map((item) {
|
||||||
|
return PopupMenuItem<String>(
|
||||||
|
value: item.itemValue,
|
||||||
|
child: Container(
|
||||||
|
margin:
|
||||||
|
EdgeInsets.only(left: 0.w, right: 0, top: 0, bottom: 0),
|
||||||
|
color: item.itemValue == currentValue
|
||||||
|
? AppColors.mainColor
|
||||||
|
: null, // 设置选中项背景色为蓝色
|
||||||
|
child: Text(
|
||||||
|
item.itemTitle,
|
||||||
|
style: TextStyle(
|
||||||
|
color: item.itemValue == currentValue
|
||||||
|
? Colors.white
|
||||||
|
: Colors.black, // 设置选中项文字颜色为白色
|
||||||
|
),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
);
|
||||||
|
}).toList();
|
||||||
|
},
|
||||||
|
// itemBuilder: (context) {
|
||||||
|
// return widget.items
|
||||||
|
// .map(
|
||||||
|
// (item) => item.itemValue == currentValue
|
||||||
|
// ? PopupMenuItem<String>(
|
||||||
|
// value: item.itemValue,
|
||||||
|
// child: Text(
|
||||||
|
// item.itemTitle,
|
||||||
|
// style: TextStyle(color: AppColors.mainColor),
|
||||||
|
// ),
|
||||||
|
// )
|
||||||
|
// : PopupMenuItem<String>(
|
||||||
|
// value: item.itemValue,
|
||||||
|
// child: Text(item.itemTitle),
|
||||||
|
// ),
|
||||||
|
// )
|
||||||
|
// .toList();
|
||||||
|
// },
|
||||||
|
)
|
||||||
|
],
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
1
star_lock/linux/.gitignore
vendored
@ -1 +0,0 @@
|
|||||||
flutter/ephemeral
|
|
||||||
@ -1,138 +0,0 @@
|
|||||||
# Project-level configuration.
|
|
||||||
cmake_minimum_required(VERSION 3.10)
|
|
||||||
project(runner LANGUAGES CXX)
|
|
||||||
|
|
||||||
# The name of the executable created for the application. Change this to change
|
|
||||||
# the on-disk name of your application.
|
|
||||||
set(BINARY_NAME "star_lock")
|
|
||||||
# The unique GTK application identifier for this application. See:
|
|
||||||
# https://wiki.gnome.org/HowDoI/ChooseApplicationID
|
|
||||||
set(APPLICATION_ID "com.example.star_lock")
|
|
||||||
|
|
||||||
# Explicitly opt in to modern CMake behaviors to avoid warnings with recent
|
|
||||||
# versions of CMake.
|
|
||||||
cmake_policy(SET CMP0063 NEW)
|
|
||||||
|
|
||||||
# Load bundled libraries from the lib/ directory relative to the binary.
|
|
||||||
set(CMAKE_INSTALL_RPATH "$ORIGIN/lib")
|
|
||||||
|
|
||||||
# Root filesystem for cross-building.
|
|
||||||
if(FLUTTER_TARGET_PLATFORM_SYSROOT)
|
|
||||||
set(CMAKE_SYSROOT ${FLUTTER_TARGET_PLATFORM_SYSROOT})
|
|
||||||
set(CMAKE_FIND_ROOT_PATH ${CMAKE_SYSROOT})
|
|
||||||
set(CMAKE_FIND_ROOT_PATH_MODE_PROGRAM NEVER)
|
|
||||||
set(CMAKE_FIND_ROOT_PATH_MODE_PACKAGE ONLY)
|
|
||||||
set(CMAKE_FIND_ROOT_PATH_MODE_LIBRARY ONLY)
|
|
||||||
set(CMAKE_FIND_ROOT_PATH_MODE_INCLUDE ONLY)
|
|
||||||
endif()
|
|
||||||
|
|
||||||
# Define build configuration options.
|
|
||||||
if(NOT CMAKE_BUILD_TYPE AND NOT CMAKE_CONFIGURATION_TYPES)
|
|
||||||
set(CMAKE_BUILD_TYPE "Debug" CACHE
|
|
||||||
STRING "Flutter build mode" FORCE)
|
|
||||||
set_property(CACHE CMAKE_BUILD_TYPE PROPERTY STRINGS
|
|
||||||
"Debug" "Profile" "Release")
|
|
||||||
endif()
|
|
||||||
|
|
||||||
# Compilation settings that should be applied to most targets.
|
|
||||||
#
|
|
||||||
# Be cautious about adding new options here, as plugins use this function by
|
|
||||||
# default. In most cases, you should add new options to specific targets instead
|
|
||||||
# of modifying this function.
|
|
||||||
function(APPLY_STANDARD_SETTINGS TARGET)
|
|
||||||
target_compile_features(${TARGET} PUBLIC cxx_std_14)
|
|
||||||
target_compile_options(${TARGET} PRIVATE -Wall -Werror)
|
|
||||||
target_compile_options(${TARGET} PRIVATE "$<$<NOT:$<CONFIG:Debug>>:-O3>")
|
|
||||||
target_compile_definitions(${TARGET} PRIVATE "$<$<NOT:$<CONFIG:Debug>>:NDEBUG>")
|
|
||||||
endfunction()
|
|
||||||
|
|
||||||
# Flutter library and tool build rules.
|
|
||||||
set(FLUTTER_MANAGED_DIR "${CMAKE_CURRENT_SOURCE_DIR}/flutter")
|
|
||||||
add_subdirectory(${FLUTTER_MANAGED_DIR})
|
|
||||||
|
|
||||||
# System-level dependencies.
|
|
||||||
find_package(PkgConfig REQUIRED)
|
|
||||||
pkg_check_modules(GTK REQUIRED IMPORTED_TARGET gtk+-3.0)
|
|
||||||
|
|
||||||
add_definitions(-DAPPLICATION_ID="${APPLICATION_ID}")
|
|
||||||
|
|
||||||
# Define the application target. To change its name, change BINARY_NAME above,
|
|
||||||
# not the value here, or `flutter run` will no longer work.
|
|
||||||
#
|
|
||||||
# Any new source files that you add to the application should be added here.
|
|
||||||
add_executable(${BINARY_NAME}
|
|
||||||
"main.cc"
|
|
||||||
"my_application.cc"
|
|
||||||
"${FLUTTER_MANAGED_DIR}/generated_plugin_registrant.cc"
|
|
||||||
)
|
|
||||||
|
|
||||||
# Apply the standard set of build settings. This can be removed for applications
|
|
||||||
# that need different build settings.
|
|
||||||
apply_standard_settings(${BINARY_NAME})
|
|
||||||
|
|
||||||
# Add dependency libraries. Add any application-specific dependencies here.
|
|
||||||
target_link_libraries(${BINARY_NAME} PRIVATE flutter)
|
|
||||||
target_link_libraries(${BINARY_NAME} PRIVATE PkgConfig::GTK)
|
|
||||||
|
|
||||||
# Run the Flutter tool portions of the build. This must not be removed.
|
|
||||||
add_dependencies(${BINARY_NAME} flutter_assemble)
|
|
||||||
|
|
||||||
# Only the install-generated bundle's copy of the executable will launch
|
|
||||||
# correctly, since the resources must in the right relative locations. To avoid
|
|
||||||
# people trying to run the unbundled copy, put it in a subdirectory instead of
|
|
||||||
# the default top-level location.
|
|
||||||
set_target_properties(${BINARY_NAME}
|
|
||||||
PROPERTIES
|
|
||||||
RUNTIME_OUTPUT_DIRECTORY "${CMAKE_BINARY_DIR}/intermediates_do_not_run"
|
|
||||||
)
|
|
||||||
|
|
||||||
# Generated plugin build rules, which manage building the plugins and adding
|
|
||||||
# them to the application.
|
|
||||||
include(flutter/generated_plugins.cmake)
|
|
||||||
|
|
||||||
|
|
||||||
# === Installation ===
|
|
||||||
# By default, "installing" just makes a relocatable bundle in the build
|
|
||||||
# directory.
|
|
||||||
set(BUILD_BUNDLE_DIR "${PROJECT_BINARY_DIR}/bundle")
|
|
||||||
if(CMAKE_INSTALL_PREFIX_INITIALIZED_TO_DEFAULT)
|
|
||||||
set(CMAKE_INSTALL_PREFIX "${BUILD_BUNDLE_DIR}" CACHE PATH "..." FORCE)
|
|
||||||
endif()
|
|
||||||
|
|
||||||
# Start with a clean build bundle directory every time.
|
|
||||||
install(CODE "
|
|
||||||
file(REMOVE_RECURSE \"${BUILD_BUNDLE_DIR}/\")
|
|
||||||
" COMPONENT Runtime)
|
|
||||||
|
|
||||||
set(INSTALL_BUNDLE_DATA_DIR "${CMAKE_INSTALL_PREFIX}/data")
|
|
||||||
set(INSTALL_BUNDLE_LIB_DIR "${CMAKE_INSTALL_PREFIX}/lib")
|
|
||||||
|
|
||||||
install(TARGETS ${BINARY_NAME} RUNTIME DESTINATION "${CMAKE_INSTALL_PREFIX}"
|
|
||||||
COMPONENT Runtime)
|
|
||||||
|
|
||||||
install(FILES "${FLUTTER_ICU_DATA_FILE}" DESTINATION "${INSTALL_BUNDLE_DATA_DIR}"
|
|
||||||
COMPONENT Runtime)
|
|
||||||
|
|
||||||
install(FILES "${FLUTTER_LIBRARY}" DESTINATION "${INSTALL_BUNDLE_LIB_DIR}"
|
|
||||||
COMPONENT Runtime)
|
|
||||||
|
|
||||||
foreach(bundled_library ${PLUGIN_BUNDLED_LIBRARIES})
|
|
||||||
install(FILES "${bundled_library}"
|
|
||||||
DESTINATION "${INSTALL_BUNDLE_LIB_DIR}"
|
|
||||||
COMPONENT Runtime)
|
|
||||||
endforeach(bundled_library)
|
|
||||||
|
|
||||||
# Fully re-copy the assets directory on each build to avoid having stale files
|
|
||||||
# from a previous install.
|
|
||||||
set(FLUTTER_ASSET_DIR_NAME "flutter_assets")
|
|
||||||
install(CODE "
|
|
||||||
file(REMOVE_RECURSE \"${INSTALL_BUNDLE_DATA_DIR}/${FLUTTER_ASSET_DIR_NAME}\")
|
|
||||||
" COMPONENT Runtime)
|
|
||||||
install(DIRECTORY "${PROJECT_BUILD_DIR}/${FLUTTER_ASSET_DIR_NAME}"
|
|
||||||
DESTINATION "${INSTALL_BUNDLE_DATA_DIR}" COMPONENT Runtime)
|
|
||||||
|
|
||||||
# Install the AOT library on non-Debug builds only.
|
|
||||||
if(NOT CMAKE_BUILD_TYPE MATCHES "Debug")
|
|
||||||
install(FILES "${AOT_LIBRARY}" DESTINATION "${INSTALL_BUNDLE_LIB_DIR}"
|
|
||||||
COMPONENT Runtime)
|
|
||||||
endif()
|
|
||||||
@ -1,88 +0,0 @@
|
|||||||
# This file controls Flutter-level build steps. It should not be edited.
|
|
||||||
cmake_minimum_required(VERSION 3.10)
|
|
||||||
|
|
||||||
set(EPHEMERAL_DIR "${CMAKE_CURRENT_SOURCE_DIR}/ephemeral")
|
|
||||||
|
|
||||||
# Configuration provided via flutter tool.
|
|
||||||
include(${EPHEMERAL_DIR}/generated_config.cmake)
|
|
||||||
|
|
||||||
# TODO: Move the rest of this into files in ephemeral. See
|
|
||||||
# https://github.com/flutter/flutter/issues/57146.
|
|
||||||
|
|
||||||
# Serves the same purpose as list(TRANSFORM ... PREPEND ...),
|
|
||||||
# which isn't available in 3.10.
|
|
||||||
function(list_prepend LIST_NAME PREFIX)
|
|
||||||
set(NEW_LIST "")
|
|
||||||
foreach(element ${${LIST_NAME}})
|
|
||||||
list(APPEND NEW_LIST "${PREFIX}${element}")
|
|
||||||
endforeach(element)
|
|
||||||
set(${LIST_NAME} "${NEW_LIST}" PARENT_SCOPE)
|
|
||||||
endfunction()
|
|
||||||
|
|
||||||
# === Flutter Library ===
|
|
||||||
# System-level dependencies.
|
|
||||||
find_package(PkgConfig REQUIRED)
|
|
||||||
pkg_check_modules(GTK REQUIRED IMPORTED_TARGET gtk+-3.0)
|
|
||||||
pkg_check_modules(GLIB REQUIRED IMPORTED_TARGET glib-2.0)
|
|
||||||
pkg_check_modules(GIO REQUIRED IMPORTED_TARGET gio-2.0)
|
|
||||||
|
|
||||||
set(FLUTTER_LIBRARY "${EPHEMERAL_DIR}/libflutter_linux_gtk.so")
|
|
||||||
|
|
||||||
# Published to parent scope for install step.
|
|
||||||
set(FLUTTER_LIBRARY ${FLUTTER_LIBRARY} PARENT_SCOPE)
|
|
||||||
set(FLUTTER_ICU_DATA_FILE "${EPHEMERAL_DIR}/icudtl.dat" PARENT_SCOPE)
|
|
||||||
set(PROJECT_BUILD_DIR "${PROJECT_DIR}/build/" PARENT_SCOPE)
|
|
||||||
set(AOT_LIBRARY "${PROJECT_DIR}/build/lib/libapp.so" PARENT_SCOPE)
|
|
||||||
|
|
||||||
list(APPEND FLUTTER_LIBRARY_HEADERS
|
|
||||||
"fl_basic_message_channel.h"
|
|
||||||
"fl_binary_codec.h"
|
|
||||||
"fl_binary_messenger.h"
|
|
||||||
"fl_dart_project.h"
|
|
||||||
"fl_engine.h"
|
|
||||||
"fl_json_message_codec.h"
|
|
||||||
"fl_json_method_codec.h"
|
|
||||||
"fl_message_codec.h"
|
|
||||||
"fl_method_call.h"
|
|
||||||
"fl_method_channel.h"
|
|
||||||
"fl_method_codec.h"
|
|
||||||
"fl_method_response.h"
|
|
||||||
"fl_plugin_registrar.h"
|
|
||||||
"fl_plugin_registry.h"
|
|
||||||
"fl_standard_message_codec.h"
|
|
||||||
"fl_standard_method_codec.h"
|
|
||||||
"fl_string_codec.h"
|
|
||||||
"fl_value.h"
|
|
||||||
"fl_view.h"
|
|
||||||
"flutter_linux.h"
|
|
||||||
)
|
|
||||||
list_prepend(FLUTTER_LIBRARY_HEADERS "${EPHEMERAL_DIR}/flutter_linux/")
|
|
||||||
add_library(flutter INTERFACE)
|
|
||||||
target_include_directories(flutter INTERFACE
|
|
||||||
"${EPHEMERAL_DIR}"
|
|
||||||
)
|
|
||||||
target_link_libraries(flutter INTERFACE "${FLUTTER_LIBRARY}")
|
|
||||||
target_link_libraries(flutter INTERFACE
|
|
||||||
PkgConfig::GTK
|
|
||||||
PkgConfig::GLIB
|
|
||||||
PkgConfig::GIO
|
|
||||||
)
|
|
||||||
add_dependencies(flutter flutter_assemble)
|
|
||||||
|
|
||||||
# === Flutter tool backend ===
|
|
||||||
# _phony_ is a non-existent file to force this command to run every time,
|
|
||||||
# since currently there's no way to get a full input/output list from the
|
|
||||||
# flutter tool.
|
|
||||||
add_custom_command(
|
|
||||||
OUTPUT ${FLUTTER_LIBRARY} ${FLUTTER_LIBRARY_HEADERS}
|
|
||||||
${CMAKE_CURRENT_BINARY_DIR}/_phony_
|
|
||||||
COMMAND ${CMAKE_COMMAND} -E env
|
|
||||||
${FLUTTER_TOOL_ENVIRONMENT}
|
|
||||||
"${FLUTTER_ROOT}/packages/flutter_tools/bin/tool_backend.sh"
|
|
||||||
${FLUTTER_TARGET_PLATFORM} ${CMAKE_BUILD_TYPE}
|
|
||||||
VERBATIM
|
|
||||||
)
|
|
||||||
add_custom_target(flutter_assemble DEPENDS
|
|
||||||
"${FLUTTER_LIBRARY}"
|
|
||||||
${FLUTTER_LIBRARY_HEADERS}
|
|
||||||
)
|
|
||||||
@ -1,27 +0,0 @@
|
|||||||
//
|
|
||||||
// Generated file. Do not edit.
|
|
||||||
//
|
|
||||||
|
|
||||||
// clang-format off
|
|
||||||
|
|
||||||
#include "generated_plugin_registrant.h"
|
|
||||||
|
|
||||||
#include <aj_captcha_flutter/aj_captcha_flutter_plugin.h>
|
|
||||||
#include <audioplayers_linux/audioplayers_linux_plugin.h>
|
|
||||||
#include <file_selector_linux/file_selector_plugin.h>
|
|
||||||
#include <url_launcher_linux/url_launcher_plugin.h>
|
|
||||||
|
|
||||||
void fl_register_plugins(FlPluginRegistry* registry) {
|
|
||||||
g_autoptr(FlPluginRegistrar) aj_captcha_flutter_registrar =
|
|
||||||
fl_plugin_registry_get_registrar_for_plugin(registry, "AjCaptchaFlutterPlugin");
|
|
||||||
aj_captcha_flutter_plugin_register_with_registrar(aj_captcha_flutter_registrar);
|
|
||||||
g_autoptr(FlPluginRegistrar) audioplayers_linux_registrar =
|
|
||||||
fl_plugin_registry_get_registrar_for_plugin(registry, "AudioplayersLinuxPlugin");
|
|
||||||
audioplayers_linux_plugin_register_with_registrar(audioplayers_linux_registrar);
|
|
||||||
g_autoptr(FlPluginRegistrar) file_selector_linux_registrar =
|
|
||||||
fl_plugin_registry_get_registrar_for_plugin(registry, "FileSelectorPlugin");
|
|
||||||
file_selector_plugin_register_with_registrar(file_selector_linux_registrar);
|
|
||||||
g_autoptr(FlPluginRegistrar) url_launcher_linux_registrar =
|
|
||||||
fl_plugin_registry_get_registrar_for_plugin(registry, "UrlLauncherPlugin");
|
|
||||||
url_launcher_plugin_register_with_registrar(url_launcher_linux_registrar);
|
|
||||||
}
|
|
||||||
@ -1,15 +0,0 @@
|
|||||||
//
|
|
||||||
// Generated file. Do not edit.
|
|
||||||
//
|
|
||||||
|
|
||||||
// clang-format off
|
|
||||||
|
|
||||||
#ifndef GENERATED_PLUGIN_REGISTRANT_
|
|
||||||
#define GENERATED_PLUGIN_REGISTRANT_
|
|
||||||
|
|
||||||
#include <flutter_linux/flutter_linux.h>
|
|
||||||
|
|
||||||
// Registers Flutter plugins.
|
|
||||||
void fl_register_plugins(FlPluginRegistry* registry);
|
|
||||||
|
|
||||||
#endif // GENERATED_PLUGIN_REGISTRANT_
|
|
||||||
@ -1,27 +0,0 @@
|
|||||||
#
|
|
||||||
# Generated file, do not edit.
|
|
||||||
#
|
|
||||||
|
|
||||||
list(APPEND FLUTTER_PLUGIN_LIST
|
|
||||||
aj_captcha_flutter
|
|
||||||
audioplayers_linux
|
|
||||||
file_selector_linux
|
|
||||||
url_launcher_linux
|
|
||||||
)
|
|
||||||
|
|
||||||
list(APPEND FLUTTER_FFI_PLUGIN_LIST
|
|
||||||
)
|
|
||||||
|
|
||||||
set(PLUGIN_BUNDLED_LIBRARIES)
|
|
||||||
|
|
||||||
foreach(plugin ${FLUTTER_PLUGIN_LIST})
|
|
||||||
add_subdirectory(flutter/ephemeral/.plugin_symlinks/${plugin}/linux plugins/${plugin})
|
|
||||||
target_link_libraries(${BINARY_NAME} PRIVATE ${plugin}_plugin)
|
|
||||||
list(APPEND PLUGIN_BUNDLED_LIBRARIES $<TARGET_FILE:${plugin}_plugin>)
|
|
||||||
list(APPEND PLUGIN_BUNDLED_LIBRARIES ${${plugin}_bundled_libraries})
|
|
||||||
endforeach(plugin)
|
|
||||||
|
|
||||||
foreach(ffi_plugin ${FLUTTER_FFI_PLUGIN_LIST})
|
|
||||||
add_subdirectory(flutter/ephemeral/.plugin_symlinks/${ffi_plugin}/linux plugins/${ffi_plugin})
|
|
||||||
list(APPEND PLUGIN_BUNDLED_LIBRARIES ${${ffi_plugin}_bundled_libraries})
|
|
||||||
endforeach(ffi_plugin)
|
|
||||||
@ -1,6 +0,0 @@
|
|||||||
#include "my_application.h"
|
|
||||||
|
|
||||||
int main(int argc, char** argv) {
|
|
||||||
g_autoptr(MyApplication) app = my_application_new();
|
|
||||||
return g_application_run(G_APPLICATION(app), argc, argv);
|
|
||||||
}
|
|
||||||
@ -1,104 +0,0 @@
|
|||||||
#include "my_application.h"
|
|
||||||
|
|
||||||
#include <flutter_linux/flutter_linux.h>
|
|
||||||
#ifdef GDK_WINDOWING_X11
|
|
||||||
#include <gdk/gdkx.h>
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#include "flutter/generated_plugin_registrant.h"
|
|
||||||
|
|
||||||
struct _MyApplication {
|
|
||||||
GtkApplication parent_instance;
|
|
||||||
char** dart_entrypoint_arguments;
|
|
||||||
};
|
|
||||||
|
|
||||||
G_DEFINE_TYPE(MyApplication, my_application, GTK_TYPE_APPLICATION)
|
|
||||||
|
|
||||||
// Implements GApplication::activate.
|
|
||||||
static void my_application_activate(GApplication* application) {
|
|
||||||
MyApplication* self = MY_APPLICATION(application);
|
|
||||||
GtkWindow* window =
|
|
||||||
GTK_WINDOW(gtk_application_window_new(GTK_APPLICATION(application)));
|
|
||||||
|
|
||||||
// Use a header bar when running in GNOME as this is the common style used
|
|
||||||
// by applications and is the setup most users will be using (e.g. Ubuntu
|
|
||||||
// desktop).
|
|
||||||
// If running on X and not using GNOME then just use a traditional title bar
|
|
||||||
// in case the window manager does more exotic layout, e.g. tiling.
|
|
||||||
// If running on Wayland assume the header bar will work (may need changing
|
|
||||||
// if future cases occur).
|
|
||||||
gboolean use_header_bar = TRUE;
|
|
||||||
#ifdef GDK_WINDOWING_X11
|
|
||||||
GdkScreen* screen = gtk_window_get_screen(window);
|
|
||||||
if (GDK_IS_X11_SCREEN(screen)) {
|
|
||||||
const gchar* wm_name = gdk_x11_screen_get_window_manager_name(screen);
|
|
||||||
if (g_strcmp0(wm_name, "GNOME Shell") != 0) {
|
|
||||||
use_header_bar = FALSE;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
if (use_header_bar) {
|
|
||||||
GtkHeaderBar* header_bar = GTK_HEADER_BAR(gtk_header_bar_new());
|
|
||||||
gtk_widget_show(GTK_WIDGET(header_bar));
|
|
||||||
gtk_header_bar_set_title(header_bar, "star_lock");
|
|
||||||
gtk_header_bar_set_show_close_button(header_bar, TRUE);
|
|
||||||
gtk_window_set_titlebar(window, GTK_WIDGET(header_bar));
|
|
||||||
} else {
|
|
||||||
gtk_window_set_title(window, "star_lock");
|
|
||||||
}
|
|
||||||
|
|
||||||
gtk_window_set_default_size(window, 1280, 720);
|
|
||||||
gtk_widget_show(GTK_WIDGET(window));
|
|
||||||
|
|
||||||
g_autoptr(FlDartProject) project = fl_dart_project_new();
|
|
||||||
fl_dart_project_set_dart_entrypoint_arguments(project, self->dart_entrypoint_arguments);
|
|
||||||
|
|
||||||
FlView* view = fl_view_new(project);
|
|
||||||
gtk_widget_show(GTK_WIDGET(view));
|
|
||||||
gtk_container_add(GTK_CONTAINER(window), GTK_WIDGET(view));
|
|
||||||
|
|
||||||
fl_register_plugins(FL_PLUGIN_REGISTRY(view));
|
|
||||||
|
|
||||||
gtk_widget_grab_focus(GTK_WIDGET(view));
|
|
||||||
}
|
|
||||||
|
|
||||||
// Implements GApplication::local_command_line.
|
|
||||||
static gboolean my_application_local_command_line(GApplication* application, gchar*** arguments, int* exit_status) {
|
|
||||||
MyApplication* self = MY_APPLICATION(application);
|
|
||||||
// Strip out the first argument as it is the binary name.
|
|
||||||
self->dart_entrypoint_arguments = g_strdupv(*arguments + 1);
|
|
||||||
|
|
||||||
g_autoptr(GError) error = nullptr;
|
|
||||||
if (!g_application_register(application, nullptr, &error)) {
|
|
||||||
g_warning("Failed to register: %s", error->message);
|
|
||||||
*exit_status = 1;
|
|
||||||
return TRUE;
|
|
||||||
}
|
|
||||||
|
|
||||||
g_application_activate(application);
|
|
||||||
*exit_status = 0;
|
|
||||||
|
|
||||||
return TRUE;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Implements GObject::dispose.
|
|
||||||
static void my_application_dispose(GObject* object) {
|
|
||||||
MyApplication* self = MY_APPLICATION(object);
|
|
||||||
g_clear_pointer(&self->dart_entrypoint_arguments, g_strfreev);
|
|
||||||
G_OBJECT_CLASS(my_application_parent_class)->dispose(object);
|
|
||||||
}
|
|
||||||
|
|
||||||
static void my_application_class_init(MyApplicationClass* klass) {
|
|
||||||
G_APPLICATION_CLASS(klass)->activate = my_application_activate;
|
|
||||||
G_APPLICATION_CLASS(klass)->local_command_line = my_application_local_command_line;
|
|
||||||
G_OBJECT_CLASS(klass)->dispose = my_application_dispose;
|
|
||||||
}
|
|
||||||
|
|
||||||
static void my_application_init(MyApplication* self) {}
|
|
||||||
|
|
||||||
MyApplication* my_application_new() {
|
|
||||||
return MY_APPLICATION(g_object_new(my_application_get_type(),
|
|
||||||
"application-id", APPLICATION_ID,
|
|
||||||
"flags", G_APPLICATION_NON_UNIQUE,
|
|
||||||
nullptr));
|
|
||||||
}
|
|
||||||
@ -1,18 +0,0 @@
|
|||||||
#ifndef FLUTTER_MY_APPLICATION_H_
|
|
||||||
#define FLUTTER_MY_APPLICATION_H_
|
|
||||||
|
|
||||||
#include <gtk/gtk.h>
|
|
||||||
|
|
||||||
G_DECLARE_FINAL_TYPE(MyApplication, my_application, MY, APPLICATION,
|
|
||||||
GtkApplication)
|
|
||||||
|
|
||||||
/**
|
|
||||||
* my_application_new:
|
|
||||||
*
|
|
||||||
* Creates a new Flutter-based application.
|
|
||||||
*
|
|
||||||
* Returns: a new #MyApplication.
|
|
||||||
*/
|
|
||||||
MyApplication* my_application_new();
|
|
||||||
|
|
||||||
#endif // FLUTTER_MY_APPLICATION_H_
|
|
||||||
7
star_lock/macos/.gitignore
vendored
@ -1,7 +0,0 @@
|
|||||||
# Flutter-related
|
|
||||||
**/Flutter/ephemeral/
|
|
||||||
**/Pods/
|
|
||||||
|
|
||||||
# Xcode-related
|
|
||||||
**/dgph
|
|
||||||
**/xcuserdata/
|
|
||||||
@ -1,2 +0,0 @@
|
|||||||
#include? "Pods/Target Support Files/Pods-Runner/Pods-Runner.debug.xcconfig"
|
|
||||||
#include "ephemeral/Flutter-Generated.xcconfig"
|
|
||||||
@ -1,2 +0,0 @@
|
|||||||
#include? "Pods/Target Support Files/Pods-Runner/Pods-Runner.release.xcconfig"
|
|
||||||
#include "ephemeral/Flutter-Generated.xcconfig"
|
|
||||||
@ -1,38 +0,0 @@
|
|||||||
//
|
|
||||||
// Generated file. Do not edit.
|
|
||||||
//
|
|
||||||
|
|
||||||
import FlutterMacOS
|
|
||||||
import Foundation
|
|
||||||
|
|
||||||
import aj_captcha_flutter
|
|
||||||
import audio_session
|
|
||||||
import audioplayers_darwin
|
|
||||||
import connectivity_plus
|
|
||||||
import device_info_plus
|
|
||||||
import file_selector_macos
|
|
||||||
import flutter_pcm_sound
|
|
||||||
import just_audio
|
|
||||||
import network_info_plus
|
|
||||||
import package_info_plus
|
|
||||||
import path_provider_foundation
|
|
||||||
import shared_preferences_foundation
|
|
||||||
import sqflite
|
|
||||||
import url_launcher_macos
|
|
||||||
|
|
||||||
func RegisterGeneratedPlugins(registry: FlutterPluginRegistry) {
|
|
||||||
AjCaptchaFlutterPlugin.register(with: registry.registrar(forPlugin: "AjCaptchaFlutterPlugin"))
|
|
||||||
AudioSessionPlugin.register(with: registry.registrar(forPlugin: "AudioSessionPlugin"))
|
|
||||||
AudioplayersDarwinPlugin.register(with: registry.registrar(forPlugin: "AudioplayersDarwinPlugin"))
|
|
||||||
ConnectivityPlugin.register(with: registry.registrar(forPlugin: "ConnectivityPlugin"))
|
|
||||||
DeviceInfoPlusMacosPlugin.register(with: registry.registrar(forPlugin: "DeviceInfoPlusMacosPlugin"))
|
|
||||||
FileSelectorPlugin.register(with: registry.registrar(forPlugin: "FileSelectorPlugin"))
|
|
||||||
FlutterPcmSoundPlugin.register(with: registry.registrar(forPlugin: "FlutterPcmSoundPlugin"))
|
|
||||||
JustAudioPlugin.register(with: registry.registrar(forPlugin: "JustAudioPlugin"))
|
|
||||||
NetworkInfoPlusPlugin.register(with: registry.registrar(forPlugin: "NetworkInfoPlusPlugin"))
|
|
||||||
FLTPackageInfoPlusPlugin.register(with: registry.registrar(forPlugin: "FLTPackageInfoPlusPlugin"))
|
|
||||||
PathProviderPlugin.register(with: registry.registrar(forPlugin: "PathProviderPlugin"))
|
|
||||||
SharedPreferencesPlugin.register(with: registry.registrar(forPlugin: "SharedPreferencesPlugin"))
|
|
||||||
SqflitePlugin.register(with: registry.registrar(forPlugin: "SqflitePlugin"))
|
|
||||||
UrlLauncherPlugin.register(with: registry.registrar(forPlugin: "UrlLauncherPlugin"))
|
|
||||||
}
|
|
||||||
@ -1,40 +0,0 @@
|
|||||||
platform :osx, '10.11'
|
|
||||||
|
|
||||||
# CocoaPods analytics sends network stats synchronously affecting flutter build latency.
|
|
||||||
ENV['COCOAPODS_DISABLE_STATS'] = 'true'
|
|
||||||
|
|
||||||
project 'Runner', {
|
|
||||||
'Debug' => :debug,
|
|
||||||
'Profile' => :release,
|
|
||||||
'Release' => :release,
|
|
||||||
}
|
|
||||||
|
|
||||||
def flutter_root
|
|
||||||
generated_xcode_build_settings_path = File.expand_path(File.join('..', 'Flutter', 'ephemeral', 'Flutter-Generated.xcconfig'), __FILE__)
|
|
||||||
unless File.exist?(generated_xcode_build_settings_path)
|
|
||||||
raise "#{generated_xcode_build_settings_path} must exist. If you're running pod install manually, make sure \"flutter pub get\" is executed first"
|
|
||||||
end
|
|
||||||
|
|
||||||
File.foreach(generated_xcode_build_settings_path) do |line|
|
|
||||||
matches = line.match(/FLUTTER_ROOT\=(.*)/)
|
|
||||||
return matches[1].strip if matches
|
|
||||||
end
|
|
||||||
raise "FLUTTER_ROOT not found in #{generated_xcode_build_settings_path}. Try deleting Flutter-Generated.xcconfig, then run \"flutter pub get\""
|
|
||||||
end
|
|
||||||
|
|
||||||
require File.expand_path(File.join('packages', 'flutter_tools', 'bin', 'podhelper'), flutter_root)
|
|
||||||
|
|
||||||
flutter_macos_podfile_setup
|
|
||||||
|
|
||||||
target 'Runner' do
|
|
||||||
use_frameworks!
|
|
||||||
use_modular_headers!
|
|
||||||
|
|
||||||
flutter_install_all_macos_pods File.dirname(File.realpath(__FILE__))
|
|
||||||
end
|
|
||||||
|
|
||||||
post_install do |installer|
|
|
||||||
installer.pods_project.targets.each do |target|
|
|
||||||
flutter_additional_macos_build_settings(target)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
@ -1,572 +0,0 @@
|
|||||||
// !$*UTF8*$!
|
|
||||||
{
|
|
||||||
archiveVersion = 1;
|
|
||||||
classes = {
|
|
||||||
};
|
|
||||||
objectVersion = 51;
|
|
||||||
objects = {
|
|
||||||
|
|
||||||
/* Begin PBXAggregateTarget section */
|
|
||||||
33CC111A2044C6BA0003C045 /* Flutter Assemble */ = {
|
|
||||||
isa = PBXAggregateTarget;
|
|
||||||
buildConfigurationList = 33CC111B2044C6BA0003C045 /* Build configuration list for PBXAggregateTarget "Flutter Assemble" */;
|
|
||||||
buildPhases = (
|
|
||||||
33CC111E2044C6BF0003C045 /* ShellScript */,
|
|
||||||
);
|
|
||||||
dependencies = (
|
|
||||||
);
|
|
||||||
name = "Flutter Assemble";
|
|
||||||
productName = FLX;
|
|
||||||
};
|
|
||||||
/* End PBXAggregateTarget section */
|
|
||||||
|
|
||||||
/* Begin PBXBuildFile section */
|
|
||||||
335BBD1B22A9A15E00E9071D /* GeneratedPluginRegistrant.swift in Sources */ = {isa = PBXBuildFile; fileRef = 335BBD1A22A9A15E00E9071D /* GeneratedPluginRegistrant.swift */; };
|
|
||||||
33CC10F12044A3C60003C045 /* AppDelegate.swift in Sources */ = {isa = PBXBuildFile; fileRef = 33CC10F02044A3C60003C045 /* AppDelegate.swift */; };
|
|
||||||
33CC10F32044A3C60003C045 /* Assets.xcassets in Resources */ = {isa = PBXBuildFile; fileRef = 33CC10F22044A3C60003C045 /* Assets.xcassets */; };
|
|
||||||
33CC10F62044A3C60003C045 /* MainMenu.xib in Resources */ = {isa = PBXBuildFile; fileRef = 33CC10F42044A3C60003C045 /* MainMenu.xib */; };
|
|
||||||
33CC11132044BFA00003C045 /* MainFlutterWindow.swift in Sources */ = {isa = PBXBuildFile; fileRef = 33CC11122044BFA00003C045 /* MainFlutterWindow.swift */; };
|
|
||||||
/* End PBXBuildFile section */
|
|
||||||
|
|
||||||
/* Begin PBXContainerItemProxy section */
|
|
||||||
33CC111F2044C79F0003C045 /* PBXContainerItemProxy */ = {
|
|
||||||
isa = PBXContainerItemProxy;
|
|
||||||
containerPortal = 33CC10E52044A3C60003C045 /* Project object */;
|
|
||||||
proxyType = 1;
|
|
||||||
remoteGlobalIDString = 33CC111A2044C6BA0003C045;
|
|
||||||
remoteInfo = FLX;
|
|
||||||
};
|
|
||||||
/* End PBXContainerItemProxy section */
|
|
||||||
|
|
||||||
/* Begin PBXCopyFilesBuildPhase section */
|
|
||||||
33CC110E2044A8840003C045 /* Bundle Framework */ = {
|
|
||||||
isa = PBXCopyFilesBuildPhase;
|
|
||||||
buildActionMask = 2147483647;
|
|
||||||
dstPath = "";
|
|
||||||
dstSubfolderSpec = 10;
|
|
||||||
files = (
|
|
||||||
);
|
|
||||||
name = "Bundle Framework";
|
|
||||||
runOnlyForDeploymentPostprocessing = 0;
|
|
||||||
};
|
|
||||||
/* End PBXCopyFilesBuildPhase section */
|
|
||||||
|
|
||||||
/* Begin PBXFileReference section */
|
|
||||||
333000ED22D3DE5D00554162 /* Warnings.xcconfig */ = {isa = PBXFileReference; lastKnownFileType = text.xcconfig; path = Warnings.xcconfig; sourceTree = "<group>"; };
|
|
||||||
335BBD1A22A9A15E00E9071D /* GeneratedPluginRegistrant.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = GeneratedPluginRegistrant.swift; sourceTree = "<group>"; };
|
|
||||||
33CC10ED2044A3C60003C045 /* star_lock.app */ = {isa = PBXFileReference; explicitFileType = wrapper.application; includeInIndex = 0; path = "star_lock.app"; sourceTree = BUILT_PRODUCTS_DIR; };
|
|
||||||
33CC10F02044A3C60003C045 /* AppDelegate.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = AppDelegate.swift; sourceTree = "<group>"; };
|
|
||||||
33CC10F22044A3C60003C045 /* Assets.xcassets */ = {isa = PBXFileReference; lastKnownFileType = folder.assetcatalog; name = Assets.xcassets; path = Runner/Assets.xcassets; sourceTree = "<group>"; };
|
|
||||||
33CC10F52044A3C60003C045 /* Base */ = {isa = PBXFileReference; lastKnownFileType = file.xib; name = Base; path = Base.lproj/MainMenu.xib; sourceTree = "<group>"; };
|
|
||||||
33CC10F72044A3C60003C045 /* Info.plist */ = {isa = PBXFileReference; lastKnownFileType = text.plist.xml; name = Info.plist; path = Runner/Info.plist; sourceTree = "<group>"; };
|
|
||||||
33CC11122044BFA00003C045 /* MainFlutterWindow.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = MainFlutterWindow.swift; sourceTree = "<group>"; };
|
|
||||||
33CEB47222A05771004F2AC0 /* Flutter-Debug.xcconfig */ = {isa = PBXFileReference; lastKnownFileType = text.xcconfig; path = "Flutter-Debug.xcconfig"; sourceTree = "<group>"; };
|
|
||||||
33CEB47422A05771004F2AC0 /* Flutter-Release.xcconfig */ = {isa = PBXFileReference; lastKnownFileType = text.xcconfig; path = "Flutter-Release.xcconfig"; sourceTree = "<group>"; };
|
|
||||||
33CEB47722A0578A004F2AC0 /* Flutter-Generated.xcconfig */ = {isa = PBXFileReference; lastKnownFileType = text.xcconfig; name = "Flutter-Generated.xcconfig"; path = "ephemeral/Flutter-Generated.xcconfig"; sourceTree = "<group>"; };
|
|
||||||
33E51913231747F40026EE4D /* DebugProfile.entitlements */ = {isa = PBXFileReference; lastKnownFileType = text.plist.entitlements; path = DebugProfile.entitlements; sourceTree = "<group>"; };
|
|
||||||
33E51914231749380026EE4D /* Release.entitlements */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.plist.entitlements; path = Release.entitlements; sourceTree = "<group>"; };
|
|
||||||
33E5194F232828860026EE4D /* AppInfo.xcconfig */ = {isa = PBXFileReference; lastKnownFileType = text.xcconfig; path = AppInfo.xcconfig; sourceTree = "<group>"; };
|
|
||||||
7AFA3C8E1D35360C0083082E /* Release.xcconfig */ = {isa = PBXFileReference; lastKnownFileType = text.xcconfig; path = Release.xcconfig; sourceTree = "<group>"; };
|
|
||||||
9740EEB21CF90195004384FC /* Debug.xcconfig */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.xcconfig; path = Debug.xcconfig; sourceTree = "<group>"; };
|
|
||||||
/* End PBXFileReference section */
|
|
||||||
|
|
||||||
/* Begin PBXFrameworksBuildPhase section */
|
|
||||||
33CC10EA2044A3C60003C045 /* Frameworks */ = {
|
|
||||||
isa = PBXFrameworksBuildPhase;
|
|
||||||
buildActionMask = 2147483647;
|
|
||||||
files = (
|
|
||||||
);
|
|
||||||
runOnlyForDeploymentPostprocessing = 0;
|
|
||||||
};
|
|
||||||
/* End PBXFrameworksBuildPhase section */
|
|
||||||
|
|
||||||
/* Begin PBXGroup section */
|
|
||||||
33BA886A226E78AF003329D5 /* Configs */ = {
|
|
||||||
isa = PBXGroup;
|
|
||||||
children = (
|
|
||||||
33E5194F232828860026EE4D /* AppInfo.xcconfig */,
|
|
||||||
9740EEB21CF90195004384FC /* Debug.xcconfig */,
|
|
||||||
7AFA3C8E1D35360C0083082E /* Release.xcconfig */,
|
|
||||||
333000ED22D3DE5D00554162 /* Warnings.xcconfig */,
|
|
||||||
);
|
|
||||||
path = Configs;
|
|
||||||
sourceTree = "<group>";
|
|
||||||
};
|
|
||||||
33CC10E42044A3C60003C045 = {
|
|
||||||
isa = PBXGroup;
|
|
||||||
children = (
|
|
||||||
33FAB671232836740065AC1E /* Runner */,
|
|
||||||
33CEB47122A05771004F2AC0 /* Flutter */,
|
|
||||||
33CC10EE2044A3C60003C045 /* Products */,
|
|
||||||
D73912EC22F37F3D000D13A0 /* Frameworks */,
|
|
||||||
);
|
|
||||||
sourceTree = "<group>";
|
|
||||||
};
|
|
||||||
33CC10EE2044A3C60003C045 /* Products */ = {
|
|
||||||
isa = PBXGroup;
|
|
||||||
children = (
|
|
||||||
33CC10ED2044A3C60003C045 /* star_lock.app */,
|
|
||||||
);
|
|
||||||
name = Products;
|
|
||||||
sourceTree = "<group>";
|
|
||||||
};
|
|
||||||
33CC11242044D66E0003C045 /* Resources */ = {
|
|
||||||
isa = PBXGroup;
|
|
||||||
children = (
|
|
||||||
33CC10F22044A3C60003C045 /* Assets.xcassets */,
|
|
||||||
33CC10F42044A3C60003C045 /* MainMenu.xib */,
|
|
||||||
33CC10F72044A3C60003C045 /* Info.plist */,
|
|
||||||
);
|
|
||||||
name = Resources;
|
|
||||||
path = ..;
|
|
||||||
sourceTree = "<group>";
|
|
||||||
};
|
|
||||||
33CEB47122A05771004F2AC0 /* Flutter */ = {
|
|
||||||
isa = PBXGroup;
|
|
||||||
children = (
|
|
||||||
335BBD1A22A9A15E00E9071D /* GeneratedPluginRegistrant.swift */,
|
|
||||||
33CEB47222A05771004F2AC0 /* Flutter-Debug.xcconfig */,
|
|
||||||
33CEB47422A05771004F2AC0 /* Flutter-Release.xcconfig */,
|
|
||||||
33CEB47722A0578A004F2AC0 /* Flutter-Generated.xcconfig */,
|
|
||||||
);
|
|
||||||
path = Flutter;
|
|
||||||
sourceTree = "<group>";
|
|
||||||
};
|
|
||||||
33FAB671232836740065AC1E /* Runner */ = {
|
|
||||||
isa = PBXGroup;
|
|
||||||
children = (
|
|
||||||
33CC10F02044A3C60003C045 /* AppDelegate.swift */,
|
|
||||||
33CC11122044BFA00003C045 /* MainFlutterWindow.swift */,
|
|
||||||
33E51913231747F40026EE4D /* DebugProfile.entitlements */,
|
|
||||||
33E51914231749380026EE4D /* Release.entitlements */,
|
|
||||||
33CC11242044D66E0003C045 /* Resources */,
|
|
||||||
33BA886A226E78AF003329D5 /* Configs */,
|
|
||||||
);
|
|
||||||
path = Runner;
|
|
||||||
sourceTree = "<group>";
|
|
||||||
};
|
|
||||||
D73912EC22F37F3D000D13A0 /* Frameworks */ = {
|
|
||||||
isa = PBXGroup;
|
|
||||||
children = (
|
|
||||||
);
|
|
||||||
name = Frameworks;
|
|
||||||
sourceTree = "<group>";
|
|
||||||
};
|
|
||||||
/* End PBXGroup section */
|
|
||||||
|
|
||||||
/* Begin PBXNativeTarget section */
|
|
||||||
33CC10EC2044A3C60003C045 /* Runner */ = {
|
|
||||||
isa = PBXNativeTarget;
|
|
||||||
buildConfigurationList = 33CC10FB2044A3C60003C045 /* Build configuration list for PBXNativeTarget "Runner" */;
|
|
||||||
buildPhases = (
|
|
||||||
33CC10E92044A3C60003C045 /* Sources */,
|
|
||||||
33CC10EA2044A3C60003C045 /* Frameworks */,
|
|
||||||
33CC10EB2044A3C60003C045 /* Resources */,
|
|
||||||
33CC110E2044A8840003C045 /* Bundle Framework */,
|
|
||||||
3399D490228B24CF009A79C7 /* ShellScript */,
|
|
||||||
);
|
|
||||||
buildRules = (
|
|
||||||
);
|
|
||||||
dependencies = (
|
|
||||||
33CC11202044C79F0003C045 /* PBXTargetDependency */,
|
|
||||||
);
|
|
||||||
name = Runner;
|
|
||||||
productName = Runner;
|
|
||||||
productReference = 33CC10ED2044A3C60003C045 /* star_lock.app */;
|
|
||||||
productType = "com.apple.product-type.application";
|
|
||||||
};
|
|
||||||
/* End PBXNativeTarget section */
|
|
||||||
|
|
||||||
/* Begin PBXProject section */
|
|
||||||
33CC10E52044A3C60003C045 /* Project object */ = {
|
|
||||||
isa = PBXProject;
|
|
||||||
attributes = {
|
|
||||||
LastSwiftUpdateCheck = 0920;
|
|
||||||
LastUpgradeCheck = 1300;
|
|
||||||
ORGANIZATIONNAME = "";
|
|
||||||
TargetAttributes = {
|
|
||||||
33CC10EC2044A3C60003C045 = {
|
|
||||||
CreatedOnToolsVersion = 9.2;
|
|
||||||
LastSwiftMigration = 1100;
|
|
||||||
ProvisioningStyle = Automatic;
|
|
||||||
SystemCapabilities = {
|
|
||||||
com.apple.Sandbox = {
|
|
||||||
enabled = 1;
|
|
||||||
};
|
|
||||||
};
|
|
||||||
};
|
|
||||||
33CC111A2044C6BA0003C045 = {
|
|
||||||
CreatedOnToolsVersion = 9.2;
|
|
||||||
ProvisioningStyle = Manual;
|
|
||||||
};
|
|
||||||
};
|
|
||||||
};
|
|
||||||
buildConfigurationList = 33CC10E82044A3C60003C045 /* Build configuration list for PBXProject "Runner" */;
|
|
||||||
compatibilityVersion = "Xcode 9.3";
|
|
||||||
developmentRegion = en;
|
|
||||||
hasScannedForEncodings = 0;
|
|
||||||
knownRegions = (
|
|
||||||
en,
|
|
||||||
Base,
|
|
||||||
);
|
|
||||||
mainGroup = 33CC10E42044A3C60003C045;
|
|
||||||
productRefGroup = 33CC10EE2044A3C60003C045 /* Products */;
|
|
||||||
projectDirPath = "";
|
|
||||||
projectRoot = "";
|
|
||||||
targets = (
|
|
||||||
33CC10EC2044A3C60003C045 /* Runner */,
|
|
||||||
33CC111A2044C6BA0003C045 /* Flutter Assemble */,
|
|
||||||
);
|
|
||||||
};
|
|
||||||
/* End PBXProject section */
|
|
||||||
|
|
||||||
/* Begin PBXResourcesBuildPhase section */
|
|
||||||
33CC10EB2044A3C60003C045 /* Resources */ = {
|
|
||||||
isa = PBXResourcesBuildPhase;
|
|
||||||
buildActionMask = 2147483647;
|
|
||||||
files = (
|
|
||||||
33CC10F32044A3C60003C045 /* Assets.xcassets in Resources */,
|
|
||||||
33CC10F62044A3C60003C045 /* MainMenu.xib in Resources */,
|
|
||||||
);
|
|
||||||
runOnlyForDeploymentPostprocessing = 0;
|
|
||||||
};
|
|
||||||
/* End PBXResourcesBuildPhase section */
|
|
||||||
|
|
||||||
/* Begin PBXShellScriptBuildPhase section */
|
|
||||||
3399D490228B24CF009A79C7 /* ShellScript */ = {
|
|
||||||
isa = PBXShellScriptBuildPhase;
|
|
||||||
buildActionMask = 2147483647;
|
|
||||||
files = (
|
|
||||||
);
|
|
||||||
inputFileListPaths = (
|
|
||||||
);
|
|
||||||
inputPaths = (
|
|
||||||
);
|
|
||||||
outputFileListPaths = (
|
|
||||||
);
|
|
||||||
outputPaths = (
|
|
||||||
);
|
|
||||||
runOnlyForDeploymentPostprocessing = 0;
|
|
||||||
shellPath = /bin/sh;
|
|
||||||
shellScript = "echo \"$PRODUCT_NAME.app\" > \"$PROJECT_DIR\"/Flutter/ephemeral/.app_filename && \"$FLUTTER_ROOT\"/packages/flutter_tools/bin/macos_assemble.sh embed\n";
|
|
||||||
};
|
|
||||||
33CC111E2044C6BF0003C045 /* ShellScript */ = {
|
|
||||||
isa = PBXShellScriptBuildPhase;
|
|
||||||
buildActionMask = 2147483647;
|
|
||||||
files = (
|
|
||||||
);
|
|
||||||
inputFileListPaths = (
|
|
||||||
Flutter/ephemeral/FlutterInputs.xcfilelist,
|
|
||||||
);
|
|
||||||
inputPaths = (
|
|
||||||
Flutter/ephemeral/tripwire,
|
|
||||||
);
|
|
||||||
outputFileListPaths = (
|
|
||||||
Flutter/ephemeral/FlutterOutputs.xcfilelist,
|
|
||||||
);
|
|
||||||
outputPaths = (
|
|
||||||
);
|
|
||||||
runOnlyForDeploymentPostprocessing = 0;
|
|
||||||
shellPath = /bin/sh;
|
|
||||||
shellScript = "\"$FLUTTER_ROOT\"/packages/flutter_tools/bin/macos_assemble.sh && touch Flutter/ephemeral/tripwire";
|
|
||||||
};
|
|
||||||
/* End PBXShellScriptBuildPhase section */
|
|
||||||
|
|
||||||
/* Begin PBXSourcesBuildPhase section */
|
|
||||||
33CC10E92044A3C60003C045 /* Sources */ = {
|
|
||||||
isa = PBXSourcesBuildPhase;
|
|
||||||
buildActionMask = 2147483647;
|
|
||||||
files = (
|
|
||||||
33CC11132044BFA00003C045 /* MainFlutterWindow.swift in Sources */,
|
|
||||||
33CC10F12044A3C60003C045 /* AppDelegate.swift in Sources */,
|
|
||||||
335BBD1B22A9A15E00E9071D /* GeneratedPluginRegistrant.swift in Sources */,
|
|
||||||
);
|
|
||||||
runOnlyForDeploymentPostprocessing = 0;
|
|
||||||
};
|
|
||||||
/* End PBXSourcesBuildPhase section */
|
|
||||||
|
|
||||||
/* Begin PBXTargetDependency section */
|
|
||||||
33CC11202044C79F0003C045 /* PBXTargetDependency */ = {
|
|
||||||
isa = PBXTargetDependency;
|
|
||||||
target = 33CC111A2044C6BA0003C045 /* Flutter Assemble */;
|
|
||||||
targetProxy = 33CC111F2044C79F0003C045 /* PBXContainerItemProxy */;
|
|
||||||
};
|
|
||||||
/* End PBXTargetDependency section */
|
|
||||||
|
|
||||||
/* Begin PBXVariantGroup section */
|
|
||||||
33CC10F42044A3C60003C045 /* MainMenu.xib */ = {
|
|
||||||
isa = PBXVariantGroup;
|
|
||||||
children = (
|
|
||||||
33CC10F52044A3C60003C045 /* Base */,
|
|
||||||
);
|
|
||||||
name = MainMenu.xib;
|
|
||||||
path = Runner;
|
|
||||||
sourceTree = "<group>";
|
|
||||||
};
|
|
||||||
/* End PBXVariantGroup section */
|
|
||||||
|
|
||||||
/* Begin XCBuildConfiguration section */
|
|
||||||
338D0CE9231458BD00FA5F75 /* Profile */ = {
|
|
||||||
isa = XCBuildConfiguration;
|
|
||||||
baseConfigurationReference = 7AFA3C8E1D35360C0083082E /* Release.xcconfig */;
|
|
||||||
buildSettings = {
|
|
||||||
ALWAYS_SEARCH_USER_PATHS = NO;
|
|
||||||
CLANG_ANALYZER_NONNULL = YES;
|
|
||||||
CLANG_ANALYZER_NUMBER_OBJECT_CONVERSION = YES_AGGRESSIVE;
|
|
||||||
CLANG_CXX_LANGUAGE_STANDARD = "gnu++14";
|
|
||||||
CLANG_CXX_LIBRARY = "libc++";
|
|
||||||
CLANG_ENABLE_MODULES = YES;
|
|
||||||
CLANG_ENABLE_OBJC_ARC = YES;
|
|
||||||
CLANG_WARN_BLOCK_CAPTURE_AUTORELEASING = YES;
|
|
||||||
CLANG_WARN_BOOL_CONVERSION = YES;
|
|
||||||
CLANG_WARN_CONSTANT_CONVERSION = YES;
|
|
||||||
CLANG_WARN_DEPRECATED_OBJC_IMPLEMENTATIONS = YES;
|
|
||||||
CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR;
|
|
||||||
CLANG_WARN_DOCUMENTATION_COMMENTS = YES;
|
|
||||||
CLANG_WARN_EMPTY_BODY = YES;
|
|
||||||
CLANG_WARN_ENUM_CONVERSION = YES;
|
|
||||||
CLANG_WARN_INFINITE_RECURSION = YES;
|
|
||||||
CLANG_WARN_INT_CONVERSION = YES;
|
|
||||||
CLANG_WARN_NON_LITERAL_NULL_CONVERSION = YES;
|
|
||||||
CLANG_WARN_OBJC_LITERAL_CONVERSION = YES;
|
|
||||||
CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR;
|
|
||||||
CLANG_WARN_RANGE_LOOP_ANALYSIS = YES;
|
|
||||||
CLANG_WARN_SUSPICIOUS_MOVE = YES;
|
|
||||||
CODE_SIGN_IDENTITY = "-";
|
|
||||||
COPY_PHASE_STRIP = NO;
|
|
||||||
DEBUG_INFORMATION_FORMAT = "dwarf-with-dsym";
|
|
||||||
ENABLE_NS_ASSERTIONS = NO;
|
|
||||||
ENABLE_STRICT_OBJC_MSGSEND = YES;
|
|
||||||
GCC_C_LANGUAGE_STANDARD = gnu11;
|
|
||||||
GCC_NO_COMMON_BLOCKS = YES;
|
|
||||||
GCC_WARN_64_TO_32_BIT_CONVERSION = YES;
|
|
||||||
GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR;
|
|
||||||
GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE;
|
|
||||||
GCC_WARN_UNUSED_FUNCTION = YES;
|
|
||||||
GCC_WARN_UNUSED_VARIABLE = YES;
|
|
||||||
MACOSX_DEPLOYMENT_TARGET = 10.11;
|
|
||||||
MTL_ENABLE_DEBUG_INFO = NO;
|
|
||||||
SDKROOT = macosx;
|
|
||||||
SWIFT_COMPILATION_MODE = wholemodule;
|
|
||||||
SWIFT_OPTIMIZATION_LEVEL = "-O";
|
|
||||||
};
|
|
||||||
name = Profile;
|
|
||||||
};
|
|
||||||
338D0CEA231458BD00FA5F75 /* Profile */ = {
|
|
||||||
isa = XCBuildConfiguration;
|
|
||||||
baseConfigurationReference = 33E5194F232828860026EE4D /* AppInfo.xcconfig */;
|
|
||||||
buildSettings = {
|
|
||||||
ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon;
|
|
||||||
CLANG_ENABLE_MODULES = YES;
|
|
||||||
CODE_SIGN_ENTITLEMENTS = Runner/DebugProfile.entitlements;
|
|
||||||
CODE_SIGN_STYLE = Automatic;
|
|
||||||
COMBINE_HIDPI_IMAGES = YES;
|
|
||||||
INFOPLIST_FILE = Runner/Info.plist;
|
|
||||||
LD_RUNPATH_SEARCH_PATHS = (
|
|
||||||
"$(inherited)",
|
|
||||||
"@executable_path/../Frameworks",
|
|
||||||
);
|
|
||||||
PROVISIONING_PROFILE_SPECIFIER = "";
|
|
||||||
SWIFT_VERSION = 5.0;
|
|
||||||
};
|
|
||||||
name = Profile;
|
|
||||||
};
|
|
||||||
338D0CEB231458BD00FA5F75 /* Profile */ = {
|
|
||||||
isa = XCBuildConfiguration;
|
|
||||||
buildSettings = {
|
|
||||||
CODE_SIGN_STYLE = Manual;
|
|
||||||
PRODUCT_NAME = "$(TARGET_NAME)";
|
|
||||||
};
|
|
||||||
name = Profile;
|
|
||||||
};
|
|
||||||
33CC10F92044A3C60003C045 /* Debug */ = {
|
|
||||||
isa = XCBuildConfiguration;
|
|
||||||
baseConfigurationReference = 9740EEB21CF90195004384FC /* Debug.xcconfig */;
|
|
||||||
buildSettings = {
|
|
||||||
ALWAYS_SEARCH_USER_PATHS = NO;
|
|
||||||
CLANG_ANALYZER_NONNULL = YES;
|
|
||||||
CLANG_ANALYZER_NUMBER_OBJECT_CONVERSION = YES_AGGRESSIVE;
|
|
||||||
CLANG_CXX_LANGUAGE_STANDARD = "gnu++14";
|
|
||||||
CLANG_CXX_LIBRARY = "libc++";
|
|
||||||
CLANG_ENABLE_MODULES = YES;
|
|
||||||
CLANG_ENABLE_OBJC_ARC = YES;
|
|
||||||
CLANG_WARN_BLOCK_CAPTURE_AUTORELEASING = YES;
|
|
||||||
CLANG_WARN_BOOL_CONVERSION = YES;
|
|
||||||
CLANG_WARN_CONSTANT_CONVERSION = YES;
|
|
||||||
CLANG_WARN_DEPRECATED_OBJC_IMPLEMENTATIONS = YES;
|
|
||||||
CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR;
|
|
||||||
CLANG_WARN_DOCUMENTATION_COMMENTS = YES;
|
|
||||||
CLANG_WARN_EMPTY_BODY = YES;
|
|
||||||
CLANG_WARN_ENUM_CONVERSION = YES;
|
|
||||||
CLANG_WARN_INFINITE_RECURSION = YES;
|
|
||||||
CLANG_WARN_INT_CONVERSION = YES;
|
|
||||||
CLANG_WARN_NON_LITERAL_NULL_CONVERSION = YES;
|
|
||||||
CLANG_WARN_OBJC_LITERAL_CONVERSION = YES;
|
|
||||||
CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR;
|
|
||||||
CLANG_WARN_RANGE_LOOP_ANALYSIS = YES;
|
|
||||||
CLANG_WARN_SUSPICIOUS_MOVE = YES;
|
|
||||||
CODE_SIGN_IDENTITY = "-";
|
|
||||||
COPY_PHASE_STRIP = NO;
|
|
||||||
DEBUG_INFORMATION_FORMAT = dwarf;
|
|
||||||
ENABLE_STRICT_OBJC_MSGSEND = YES;
|
|
||||||
ENABLE_TESTABILITY = YES;
|
|
||||||
GCC_C_LANGUAGE_STANDARD = gnu11;
|
|
||||||
GCC_DYNAMIC_NO_PIC = NO;
|
|
||||||
GCC_NO_COMMON_BLOCKS = YES;
|
|
||||||
GCC_OPTIMIZATION_LEVEL = 0;
|
|
||||||
GCC_PREPROCESSOR_DEFINITIONS = (
|
|
||||||
"DEBUG=1",
|
|
||||||
"$(inherited)",
|
|
||||||
);
|
|
||||||
GCC_WARN_64_TO_32_BIT_CONVERSION = YES;
|
|
||||||
GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR;
|
|
||||||
GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE;
|
|
||||||
GCC_WARN_UNUSED_FUNCTION = YES;
|
|
||||||
GCC_WARN_UNUSED_VARIABLE = YES;
|
|
||||||
MACOSX_DEPLOYMENT_TARGET = 10.11;
|
|
||||||
MTL_ENABLE_DEBUG_INFO = YES;
|
|
||||||
ONLY_ACTIVE_ARCH = YES;
|
|
||||||
SDKROOT = macosx;
|
|
||||||
SWIFT_ACTIVE_COMPILATION_CONDITIONS = DEBUG;
|
|
||||||
SWIFT_OPTIMIZATION_LEVEL = "-Onone";
|
|
||||||
};
|
|
||||||
name = Debug;
|
|
||||||
};
|
|
||||||
33CC10FA2044A3C60003C045 /* Release */ = {
|
|
||||||
isa = XCBuildConfiguration;
|
|
||||||
baseConfigurationReference = 7AFA3C8E1D35360C0083082E /* Release.xcconfig */;
|
|
||||||
buildSettings = {
|
|
||||||
ALWAYS_SEARCH_USER_PATHS = NO;
|
|
||||||
CLANG_ANALYZER_NONNULL = YES;
|
|
||||||
CLANG_ANALYZER_NUMBER_OBJECT_CONVERSION = YES_AGGRESSIVE;
|
|
||||||
CLANG_CXX_LANGUAGE_STANDARD = "gnu++14";
|
|
||||||
CLANG_CXX_LIBRARY = "libc++";
|
|
||||||
CLANG_ENABLE_MODULES = YES;
|
|
||||||
CLANG_ENABLE_OBJC_ARC = YES;
|
|
||||||
CLANG_WARN_BLOCK_CAPTURE_AUTORELEASING = YES;
|
|
||||||
CLANG_WARN_BOOL_CONVERSION = YES;
|
|
||||||
CLANG_WARN_CONSTANT_CONVERSION = YES;
|
|
||||||
CLANG_WARN_DEPRECATED_OBJC_IMPLEMENTATIONS = YES;
|
|
||||||
CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR;
|
|
||||||
CLANG_WARN_DOCUMENTATION_COMMENTS = YES;
|
|
||||||
CLANG_WARN_EMPTY_BODY = YES;
|
|
||||||
CLANG_WARN_ENUM_CONVERSION = YES;
|
|
||||||
CLANG_WARN_INFINITE_RECURSION = YES;
|
|
||||||
CLANG_WARN_INT_CONVERSION = YES;
|
|
||||||
CLANG_WARN_NON_LITERAL_NULL_CONVERSION = YES;
|
|
||||||
CLANG_WARN_OBJC_LITERAL_CONVERSION = YES;
|
|
||||||
CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR;
|
|
||||||
CLANG_WARN_RANGE_LOOP_ANALYSIS = YES;
|
|
||||||
CLANG_WARN_SUSPICIOUS_MOVE = YES;
|
|
||||||
CODE_SIGN_IDENTITY = "-";
|
|
||||||
COPY_PHASE_STRIP = NO;
|
|
||||||
DEBUG_INFORMATION_FORMAT = "dwarf-with-dsym";
|
|
||||||
ENABLE_NS_ASSERTIONS = NO;
|
|
||||||
ENABLE_STRICT_OBJC_MSGSEND = YES;
|
|
||||||
GCC_C_LANGUAGE_STANDARD = gnu11;
|
|
||||||
GCC_NO_COMMON_BLOCKS = YES;
|
|
||||||
GCC_WARN_64_TO_32_BIT_CONVERSION = YES;
|
|
||||||
GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR;
|
|
||||||
GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE;
|
|
||||||
GCC_WARN_UNUSED_FUNCTION = YES;
|
|
||||||
GCC_WARN_UNUSED_VARIABLE = YES;
|
|
||||||
MACOSX_DEPLOYMENT_TARGET = 10.11;
|
|
||||||
MTL_ENABLE_DEBUG_INFO = NO;
|
|
||||||
SDKROOT = macosx;
|
|
||||||
SWIFT_COMPILATION_MODE = wholemodule;
|
|
||||||
SWIFT_OPTIMIZATION_LEVEL = "-O";
|
|
||||||
};
|
|
||||||
name = Release;
|
|
||||||
};
|
|
||||||
33CC10FC2044A3C60003C045 /* Debug */ = {
|
|
||||||
isa = XCBuildConfiguration;
|
|
||||||
baseConfigurationReference = 33E5194F232828860026EE4D /* AppInfo.xcconfig */;
|
|
||||||
buildSettings = {
|
|
||||||
ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon;
|
|
||||||
CLANG_ENABLE_MODULES = YES;
|
|
||||||
CODE_SIGN_ENTITLEMENTS = Runner/DebugProfile.entitlements;
|
|
||||||
CODE_SIGN_STYLE = Automatic;
|
|
||||||
COMBINE_HIDPI_IMAGES = YES;
|
|
||||||
INFOPLIST_FILE = Runner/Info.plist;
|
|
||||||
LD_RUNPATH_SEARCH_PATHS = (
|
|
||||||
"$(inherited)",
|
|
||||||
"@executable_path/../Frameworks",
|
|
||||||
);
|
|
||||||
PROVISIONING_PROFILE_SPECIFIER = "";
|
|
||||||
SWIFT_OPTIMIZATION_LEVEL = "-Onone";
|
|
||||||
SWIFT_VERSION = 5.0;
|
|
||||||
};
|
|
||||||
name = Debug;
|
|
||||||
};
|
|
||||||
33CC10FD2044A3C60003C045 /* Release */ = {
|
|
||||||
isa = XCBuildConfiguration;
|
|
||||||
baseConfigurationReference = 33E5194F232828860026EE4D /* AppInfo.xcconfig */;
|
|
||||||
buildSettings = {
|
|
||||||
ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon;
|
|
||||||
CLANG_ENABLE_MODULES = YES;
|
|
||||||
CODE_SIGN_ENTITLEMENTS = Runner/Release.entitlements;
|
|
||||||
CODE_SIGN_STYLE = Automatic;
|
|
||||||
COMBINE_HIDPI_IMAGES = YES;
|
|
||||||
INFOPLIST_FILE = Runner/Info.plist;
|
|
||||||
LD_RUNPATH_SEARCH_PATHS = (
|
|
||||||
"$(inherited)",
|
|
||||||
"@executable_path/../Frameworks",
|
|
||||||
);
|
|
||||||
PROVISIONING_PROFILE_SPECIFIER = "";
|
|
||||||
SWIFT_VERSION = 5.0;
|
|
||||||
};
|
|
||||||
name = Release;
|
|
||||||
};
|
|
||||||
33CC111C2044C6BA0003C045 /* Debug */ = {
|
|
||||||
isa = XCBuildConfiguration;
|
|
||||||
buildSettings = {
|
|
||||||
CODE_SIGN_STYLE = Manual;
|
|
||||||
PRODUCT_NAME = "$(TARGET_NAME)";
|
|
||||||
};
|
|
||||||
name = Debug;
|
|
||||||
};
|
|
||||||
33CC111D2044C6BA0003C045 /* Release */ = {
|
|
||||||
isa = XCBuildConfiguration;
|
|
||||||
buildSettings = {
|
|
||||||
CODE_SIGN_STYLE = Automatic;
|
|
||||||
PRODUCT_NAME = "$(TARGET_NAME)";
|
|
||||||
};
|
|
||||||
name = Release;
|
|
||||||
};
|
|
||||||
/* End XCBuildConfiguration section */
|
|
||||||
|
|
||||||
/* Begin XCConfigurationList section */
|
|
||||||
33CC10E82044A3C60003C045 /* Build configuration list for PBXProject "Runner" */ = {
|
|
||||||
isa = XCConfigurationList;
|
|
||||||
buildConfigurations = (
|
|
||||||
33CC10F92044A3C60003C045 /* Debug */,
|
|
||||||
33CC10FA2044A3C60003C045 /* Release */,
|
|
||||||
338D0CE9231458BD00FA5F75 /* Profile */,
|
|
||||||
);
|
|
||||||
defaultConfigurationIsVisible = 0;
|
|
||||||
defaultConfigurationName = Release;
|
|
||||||
};
|
|
||||||
33CC10FB2044A3C60003C045 /* Build configuration list for PBXNativeTarget "Runner" */ = {
|
|
||||||
isa = XCConfigurationList;
|
|
||||||
buildConfigurations = (
|
|
||||||
33CC10FC2044A3C60003C045 /* Debug */,
|
|
||||||
33CC10FD2044A3C60003C045 /* Release */,
|
|
||||||
338D0CEA231458BD00FA5F75 /* Profile */,
|
|
||||||
);
|
|
||||||
defaultConfigurationIsVisible = 0;
|
|
||||||
defaultConfigurationName = Release;
|
|
||||||
};
|
|
||||||
33CC111B2044C6BA0003C045 /* Build configuration list for PBXAggregateTarget "Flutter Assemble" */ = {
|
|
||||||
isa = XCConfigurationList;
|
|
||||||
buildConfigurations = (
|
|
||||||
33CC111C2044C6BA0003C045 /* Debug */,
|
|
||||||
33CC111D2044C6BA0003C045 /* Release */,
|
|
||||||
338D0CEB231458BD00FA5F75 /* Profile */,
|
|
||||||
);
|
|
||||||
defaultConfigurationIsVisible = 0;
|
|
||||||
defaultConfigurationName = Release;
|
|
||||||
};
|
|
||||||
/* End XCConfigurationList section */
|
|
||||||
};
|
|
||||||
rootObject = 33CC10E52044A3C60003C045 /* Project object */;
|
|
||||||
}
|
|
||||||
@ -1,8 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8"?>
|
|
||||||
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
|
|
||||||
<plist version="1.0">
|
|
||||||
<dict>
|
|
||||||
<key>IDEDidComputeMac32BitWarning</key>
|
|
||||||
<true/>
|
|
||||||
</dict>
|
|
||||||
</plist>
|
|
||||||
@ -1,87 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8"?>
|
|
||||||
<Scheme
|
|
||||||
LastUpgradeVersion = "1300"
|
|
||||||
version = "1.3">
|
|
||||||
<BuildAction
|
|
||||||
parallelizeBuildables = "YES"
|
|
||||||
buildImplicitDependencies = "YES">
|
|
||||||
<BuildActionEntries>
|
|
||||||
<BuildActionEntry
|
|
||||||
buildForTesting = "YES"
|
|
||||||
buildForRunning = "YES"
|
|
||||||
buildForProfiling = "YES"
|
|
||||||
buildForArchiving = "YES"
|
|
||||||
buildForAnalyzing = "YES">
|
|
||||||
<BuildableReference
|
|
||||||
BuildableIdentifier = "primary"
|
|
||||||
BlueprintIdentifier = "33CC10EC2044A3C60003C045"
|
|
||||||
BuildableName = "star_lock.app"
|
|
||||||
BlueprintName = "Runner"
|
|
||||||
ReferencedContainer = "container:Runner.xcodeproj">
|
|
||||||
</BuildableReference>
|
|
||||||
</BuildActionEntry>
|
|
||||||
</BuildActionEntries>
|
|
||||||
</BuildAction>
|
|
||||||
<TestAction
|
|
||||||
buildConfiguration = "Debug"
|
|
||||||
selectedDebuggerIdentifier = "Xcode.DebuggerFoundation.Debugger.LLDB"
|
|
||||||
selectedLauncherIdentifier = "Xcode.DebuggerFoundation.Launcher.LLDB"
|
|
||||||
shouldUseLaunchSchemeArgsEnv = "YES">
|
|
||||||
<MacroExpansion>
|
|
||||||
<BuildableReference
|
|
||||||
BuildableIdentifier = "primary"
|
|
||||||
BlueprintIdentifier = "33CC10EC2044A3C60003C045"
|
|
||||||
BuildableName = "star_lock.app"
|
|
||||||
BlueprintName = "Runner"
|
|
||||||
ReferencedContainer = "container:Runner.xcodeproj">
|
|
||||||
</BuildableReference>
|
|
||||||
</MacroExpansion>
|
|
||||||
<Testables>
|
|
||||||
</Testables>
|
|
||||||
</TestAction>
|
|
||||||
<LaunchAction
|
|
||||||
buildConfiguration = "Debug"
|
|
||||||
selectedDebuggerIdentifier = "Xcode.DebuggerFoundation.Debugger.LLDB"
|
|
||||||
selectedLauncherIdentifier = "Xcode.DebuggerFoundation.Launcher.LLDB"
|
|
||||||
launchStyle = "0"
|
|
||||||
useCustomWorkingDirectory = "NO"
|
|
||||||
ignoresPersistentStateOnLaunch = "NO"
|
|
||||||
debugDocumentVersioning = "YES"
|
|
||||||
debugServiceExtension = "internal"
|
|
||||||
allowLocationSimulation = "YES">
|
|
||||||
<BuildableProductRunnable
|
|
||||||
runnableDebuggingMode = "0">
|
|
||||||
<BuildableReference
|
|
||||||
BuildableIdentifier = "primary"
|
|
||||||
BlueprintIdentifier = "33CC10EC2044A3C60003C045"
|
|
||||||
BuildableName = "star_lock.app"
|
|
||||||
BlueprintName = "Runner"
|
|
||||||
ReferencedContainer = "container:Runner.xcodeproj">
|
|
||||||
</BuildableReference>
|
|
||||||
</BuildableProductRunnable>
|
|
||||||
</LaunchAction>
|
|
||||||
<ProfileAction
|
|
||||||
buildConfiguration = "Profile"
|
|
||||||
shouldUseLaunchSchemeArgsEnv = "YES"
|
|
||||||
savedToolIdentifier = ""
|
|
||||||
useCustomWorkingDirectory = "NO"
|
|
||||||
debugDocumentVersioning = "YES">
|
|
||||||
<BuildableProductRunnable
|
|
||||||
runnableDebuggingMode = "0">
|
|
||||||
<BuildableReference
|
|
||||||
BuildableIdentifier = "primary"
|
|
||||||
BlueprintIdentifier = "33CC10EC2044A3C60003C045"
|
|
||||||
BuildableName = "star_lock.app"
|
|
||||||
BlueprintName = "Runner"
|
|
||||||
ReferencedContainer = "container:Runner.xcodeproj">
|
|
||||||
</BuildableReference>
|
|
||||||
</BuildableProductRunnable>
|
|
||||||
</ProfileAction>
|
|
||||||
<AnalyzeAction
|
|
||||||
buildConfiguration = "Debug">
|
|
||||||
</AnalyzeAction>
|
|
||||||
<ArchiveAction
|
|
||||||
buildConfiguration = "Release"
|
|
||||||
revealArchiveInOrganizer = "YES">
|
|
||||||
</ArchiveAction>
|
|
||||||
</Scheme>
|
|
||||||
@ -1,7 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8"?>
|
|
||||||
<Workspace
|
|
||||||
version = "1.0">
|
|
||||||
<FileRef
|
|
||||||
location = "group:Runner.xcodeproj">
|
|
||||||
</FileRef>
|
|
||||||
</Workspace>
|
|
||||||
@ -1,8 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8"?>
|
|
||||||
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
|
|
||||||
<plist version="1.0">
|
|
||||||
<dict>
|
|
||||||
<key>IDEDidComputeMac32BitWarning</key>
|
|
||||||
<true/>
|
|
||||||
</dict>
|
|
||||||
</plist>
|
|
||||||
@ -1,9 +0,0 @@
|
|||||||
import Cocoa
|
|
||||||
import FlutterMacOS
|
|
||||||
|
|
||||||
@NSApplicationMain
|
|
||||||
class AppDelegate: FlutterAppDelegate {
|
|
||||||
override func applicationShouldTerminateAfterLastWindowClosed(_ sender: NSApplication) -> Bool {
|
|
||||||
return true
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@ -1,68 +0,0 @@
|
|||||||
{
|
|
||||||
"images" : [
|
|
||||||
{
|
|
||||||
"size" : "16x16",
|
|
||||||
"idiom" : "mac",
|
|
||||||
"filename" : "app_icon_16.png",
|
|
||||||
"scale" : "1x"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"size" : "16x16",
|
|
||||||
"idiom" : "mac",
|
|
||||||
"filename" : "app_icon_32.png",
|
|
||||||
"scale" : "2x"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"size" : "32x32",
|
|
||||||
"idiom" : "mac",
|
|
||||||
"filename" : "app_icon_32.png",
|
|
||||||
"scale" : "1x"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"size" : "32x32",
|
|
||||||
"idiom" : "mac",
|
|
||||||
"filename" : "app_icon_64.png",
|
|
||||||
"scale" : "2x"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"size" : "128x128",
|
|
||||||
"idiom" : "mac",
|
|
||||||
"filename" : "app_icon_128.png",
|
|
||||||
"scale" : "1x"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"size" : "128x128",
|
|
||||||
"idiom" : "mac",
|
|
||||||
"filename" : "app_icon_256.png",
|
|
||||||
"scale" : "2x"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"size" : "256x256",
|
|
||||||
"idiom" : "mac",
|
|
||||||
"filename" : "app_icon_256.png",
|
|
||||||
"scale" : "1x"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"size" : "256x256",
|
|
||||||
"idiom" : "mac",
|
|
||||||
"filename" : "app_icon_512.png",
|
|
||||||
"scale" : "2x"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"size" : "512x512",
|
|
||||||
"idiom" : "mac",
|
|
||||||
"filename" : "app_icon_512.png",
|
|
||||||
"scale" : "1x"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"size" : "512x512",
|
|
||||||
"idiom" : "mac",
|
|
||||||
"filename" : "app_icon_1024.png",
|
|
||||||
"scale" : "2x"
|
|
||||||
}
|
|
||||||
],
|
|
||||||
"info" : {
|
|
||||||
"version" : 1,
|
|
||||||
"author" : "xcode"
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
Before Width: | Height: | Size: 101 KiB |
|
Before Width: | Height: | Size: 5.5 KiB |
|
Before Width: | Height: | Size: 520 B |
|
Before Width: | Height: | Size: 14 KiB |
|
Before Width: | Height: | Size: 1.0 KiB |
|
Before Width: | Height: | Size: 36 KiB |
|
Before Width: | Height: | Size: 2.2 KiB |
@ -1,343 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8"?>
|
|
||||||
<document type="com.apple.InterfaceBuilder3.Cocoa.XIB" version="3.0" toolsVersion="14490.70" targetRuntime="MacOSX.Cocoa" propertyAccessControl="none" useAutolayout="YES" customObjectInstantitationMethod="direct">
|
|
||||||
<dependencies>
|
|
||||||
<deployment identifier="macosx"/>
|
|
||||||
<plugIn identifier="com.apple.InterfaceBuilder.CocoaPlugin" version="14490.70"/>
|
|
||||||
<capability name="documents saved in the Xcode 8 format" minToolsVersion="8.0"/>
|
|
||||||
</dependencies>
|
|
||||||
<objects>
|
|
||||||
<customObject id="-2" userLabel="File's Owner" customClass="NSApplication">
|
|
||||||
<connections>
|
|
||||||
<outlet property="delegate" destination="Voe-Tx-rLC" id="GzC-gU-4Uq"/>
|
|
||||||
</connections>
|
|
||||||
</customObject>
|
|
||||||
<customObject id="-1" userLabel="First Responder" customClass="FirstResponder"/>
|
|
||||||
<customObject id="-3" userLabel="Application" customClass="NSObject"/>
|
|
||||||
<customObject id="Voe-Tx-rLC" customClass="AppDelegate" customModule="Runner" customModuleProvider="target">
|
|
||||||
<connections>
|
|
||||||
<outlet property="applicationMenu" destination="uQy-DD-JDr" id="XBo-yE-nKs"/>
|
|
||||||
<outlet property="mainFlutterWindow" destination="QvC-M9-y7g" id="gIp-Ho-8D9"/>
|
|
||||||
</connections>
|
|
||||||
</customObject>
|
|
||||||
<customObject id="YLy-65-1bz" customClass="NSFontManager"/>
|
|
||||||
<menu title="Main Menu" systemMenu="main" id="AYu-sK-qS6">
|
|
||||||
<items>
|
|
||||||
<menuItem title="APP_NAME" id="1Xt-HY-uBw">
|
|
||||||
<modifierMask key="keyEquivalentModifierMask"/>
|
|
||||||
<menu key="submenu" title="APP_NAME" systemMenu="apple" id="uQy-DD-JDr">
|
|
||||||
<items>
|
|
||||||
<menuItem title="About APP_NAME" id="5kV-Vb-QxS">
|
|
||||||
<modifierMask key="keyEquivalentModifierMask"/>
|
|
||||||
<connections>
|
|
||||||
<action selector="orderFrontStandardAboutPanel:" target="-1" id="Exp-CZ-Vem"/>
|
|
||||||
</connections>
|
|
||||||
</menuItem>
|
|
||||||
<menuItem isSeparatorItem="YES" id="VOq-y0-SEH"/>
|
|
||||||
<menuItem title="Preferences…" keyEquivalent="," id="BOF-NM-1cW"/>
|
|
||||||
<menuItem isSeparatorItem="YES" id="wFC-TO-SCJ"/>
|
|
||||||
<menuItem title="Services" id="NMo-om-nkz">
|
|
||||||
<modifierMask key="keyEquivalentModifierMask"/>
|
|
||||||
<menu key="submenu" title="Services" systemMenu="services" id="hz9-B4-Xy5"/>
|
|
||||||
</menuItem>
|
|
||||||
<menuItem isSeparatorItem="YES" id="4je-JR-u6R"/>
|
|
||||||
<menuItem title="Hide APP_NAME" keyEquivalent="h" id="Olw-nP-bQN">
|
|
||||||
<connections>
|
|
||||||
<action selector="hide:" target="-1" id="PnN-Uc-m68"/>
|
|
||||||
</connections>
|
|
||||||
</menuItem>
|
|
||||||
<menuItem title="Hide Others" keyEquivalent="h" id="Vdr-fp-XzO">
|
|
||||||
<modifierMask key="keyEquivalentModifierMask" option="YES" command="YES"/>
|
|
||||||
<connections>
|
|
||||||
<action selector="hideOtherApplications:" target="-1" id="VT4-aY-XCT"/>
|
|
||||||
</connections>
|
|
||||||
</menuItem>
|
|
||||||
<menuItem title="Show All" id="Kd2-mp-pUS">
|
|
||||||
<modifierMask key="keyEquivalentModifierMask"/>
|
|
||||||
<connections>
|
|
||||||
<action selector="unhideAllApplications:" target="-1" id="Dhg-Le-xox"/>
|
|
||||||
</connections>
|
|
||||||
</menuItem>
|
|
||||||
<menuItem isSeparatorItem="YES" id="kCx-OE-vgT"/>
|
|
||||||
<menuItem title="Quit APP_NAME" keyEquivalent="q" id="4sb-4s-VLi">
|
|
||||||
<connections>
|
|
||||||
<action selector="terminate:" target="-1" id="Te7-pn-YzF"/>
|
|
||||||
</connections>
|
|
||||||
</menuItem>
|
|
||||||
</items>
|
|
||||||
</menu>
|
|
||||||
</menuItem>
|
|
||||||
<menuItem title="Edit" id="5QF-Oa-p0T">
|
|
||||||
<modifierMask key="keyEquivalentModifierMask"/>
|
|
||||||
<menu key="submenu" title="Edit" id="W48-6f-4Dl">
|
|
||||||
<items>
|
|
||||||
<menuItem title="Undo" keyEquivalent="z" id="dRJ-4n-Yzg">
|
|
||||||
<connections>
|
|
||||||
<action selector="undo:" target="-1" id="M6e-cu-g7V"/>
|
|
||||||
</connections>
|
|
||||||
</menuItem>
|
|
||||||
<menuItem title="Redo" keyEquivalent="Z" id="6dh-zS-Vam">
|
|
||||||
<connections>
|
|
||||||
<action selector="redo:" target="-1" id="oIA-Rs-6OD"/>
|
|
||||||
</connections>
|
|
||||||
</menuItem>
|
|
||||||
<menuItem isSeparatorItem="YES" id="WRV-NI-Exz"/>
|
|
||||||
<menuItem title="Cut" keyEquivalent="x" id="uRl-iY-unG">
|
|
||||||
<connections>
|
|
||||||
<action selector="cut:" target="-1" id="YJe-68-I9s"/>
|
|
||||||
</connections>
|
|
||||||
</menuItem>
|
|
||||||
<menuItem title="Copy" keyEquivalent="c" id="x3v-GG-iWU">
|
|
||||||
<connections>
|
|
||||||
<action selector="copy:" target="-1" id="G1f-GL-Joy"/>
|
|
||||||
</connections>
|
|
||||||
</menuItem>
|
|
||||||
<menuItem title="Paste" keyEquivalent="v" id="gVA-U4-sdL">
|
|
||||||
<connections>
|
|
||||||
<action selector="paste:" target="-1" id="UvS-8e-Qdg"/>
|
|
||||||
</connections>
|
|
||||||
</menuItem>
|
|
||||||
<menuItem title="Paste and Match Style" keyEquivalent="V" id="WeT-3V-zwk">
|
|
||||||
<modifierMask key="keyEquivalentModifierMask" option="YES" command="YES"/>
|
|
||||||
<connections>
|
|
||||||
<action selector="pasteAsPlainText:" target="-1" id="cEh-KX-wJQ"/>
|
|
||||||
</connections>
|
|
||||||
</menuItem>
|
|
||||||
<menuItem title="Delete" id="pa3-QI-u2k">
|
|
||||||
<modifierMask key="keyEquivalentModifierMask"/>
|
|
||||||
<connections>
|
|
||||||
<action selector="delete:" target="-1" id="0Mk-Ml-PaM"/>
|
|
||||||
</connections>
|
|
||||||
</menuItem>
|
|
||||||
<menuItem title="Select All" keyEquivalent="a" id="Ruw-6m-B2m">
|
|
||||||
<connections>
|
|
||||||
<action selector="selectAll:" target="-1" id="VNm-Mi-diN"/>
|
|
||||||
</connections>
|
|
||||||
</menuItem>
|
|
||||||
<menuItem isSeparatorItem="YES" id="uyl-h8-XO2"/>
|
|
||||||
<menuItem title="Find" id="4EN-yA-p0u">
|
|
||||||
<modifierMask key="keyEquivalentModifierMask"/>
|
|
||||||
<menu key="submenu" title="Find" id="1b7-l0-nxx">
|
|
||||||
<items>
|
|
||||||
<menuItem title="Find…" tag="1" keyEquivalent="f" id="Xz5-n4-O0W">
|
|
||||||
<connections>
|
|
||||||
<action selector="performFindPanelAction:" target="-1" id="cD7-Qs-BN4"/>
|
|
||||||
</connections>
|
|
||||||
</menuItem>
|
|
||||||
<menuItem title="Find and Replace…" tag="12" keyEquivalent="f" id="YEy-JH-Tfz">
|
|
||||||
<modifierMask key="keyEquivalentModifierMask" option="YES" command="YES"/>
|
|
||||||
<connections>
|
|
||||||
<action selector="performFindPanelAction:" target="-1" id="WD3-Gg-5AJ"/>
|
|
||||||
</connections>
|
|
||||||
</menuItem>
|
|
||||||
<menuItem title="Find Next" tag="2" keyEquivalent="g" id="q09-fT-Sye">
|
|
||||||
<connections>
|
|
||||||
<action selector="performFindPanelAction:" target="-1" id="NDo-RZ-v9R"/>
|
|
||||||
</connections>
|
|
||||||
</menuItem>
|
|
||||||
<menuItem title="Find Previous" tag="3" keyEquivalent="G" id="OwM-mh-QMV">
|
|
||||||
<connections>
|
|
||||||
<action selector="performFindPanelAction:" target="-1" id="HOh-sY-3ay"/>
|
|
||||||
</connections>
|
|
||||||
</menuItem>
|
|
||||||
<menuItem title="Use Selection for Find" tag="7" keyEquivalent="e" id="buJ-ug-pKt">
|
|
||||||
<connections>
|
|
||||||
<action selector="performFindPanelAction:" target="-1" id="U76-nv-p5D"/>
|
|
||||||
</connections>
|
|
||||||
</menuItem>
|
|
||||||
<menuItem title="Jump to Selection" keyEquivalent="j" id="S0p-oC-mLd">
|
|
||||||
<connections>
|
|
||||||
<action selector="centerSelectionInVisibleArea:" target="-1" id="IOG-6D-g5B"/>
|
|
||||||
</connections>
|
|
||||||
</menuItem>
|
|
||||||
</items>
|
|
||||||
</menu>
|
|
||||||
</menuItem>
|
|
||||||
<menuItem title="Spelling and Grammar" id="Dv1-io-Yv7">
|
|
||||||
<modifierMask key="keyEquivalentModifierMask"/>
|
|
||||||
<menu key="submenu" title="Spelling" id="3IN-sU-3Bg">
|
|
||||||
<items>
|
|
||||||
<menuItem title="Show Spelling and Grammar" keyEquivalent=":" id="HFo-cy-zxI">
|
|
||||||
<connections>
|
|
||||||
<action selector="showGuessPanel:" target="-1" id="vFj-Ks-hy3"/>
|
|
||||||
</connections>
|
|
||||||
</menuItem>
|
|
||||||
<menuItem title="Check Document Now" keyEquivalent=";" id="hz2-CU-CR7">
|
|
||||||
<connections>
|
|
||||||
<action selector="checkSpelling:" target="-1" id="fz7-VC-reM"/>
|
|
||||||
</connections>
|
|
||||||
</menuItem>
|
|
||||||
<menuItem isSeparatorItem="YES" id="bNw-od-mp5"/>
|
|
||||||
<menuItem title="Check Spelling While Typing" id="rbD-Rh-wIN">
|
|
||||||
<modifierMask key="keyEquivalentModifierMask"/>
|
|
||||||
<connections>
|
|
||||||
<action selector="toggleContinuousSpellChecking:" target="-1" id="7w6-Qz-0kB"/>
|
|
||||||
</connections>
|
|
||||||
</menuItem>
|
|
||||||
<menuItem title="Check Grammar With Spelling" id="mK6-2p-4JG">
|
|
||||||
<modifierMask key="keyEquivalentModifierMask"/>
|
|
||||||
<connections>
|
|
||||||
<action selector="toggleGrammarChecking:" target="-1" id="muD-Qn-j4w"/>
|
|
||||||
</connections>
|
|
||||||
</menuItem>
|
|
||||||
<menuItem title="Correct Spelling Automatically" id="78Y-hA-62v">
|
|
||||||
<modifierMask key="keyEquivalentModifierMask"/>
|
|
||||||
<connections>
|
|
||||||
<action selector="toggleAutomaticSpellingCorrection:" target="-1" id="2lM-Qi-WAP"/>
|
|
||||||
</connections>
|
|
||||||
</menuItem>
|
|
||||||
</items>
|
|
||||||
</menu>
|
|
||||||
</menuItem>
|
|
||||||
<menuItem title="Substitutions" id="9ic-FL-obx">
|
|
||||||
<modifierMask key="keyEquivalentModifierMask"/>
|
|
||||||
<menu key="submenu" title="Substitutions" id="FeM-D8-WVr">
|
|
||||||
<items>
|
|
||||||
<menuItem title="Show Substitutions" id="z6F-FW-3nz">
|
|
||||||
<modifierMask key="keyEquivalentModifierMask"/>
|
|
||||||
<connections>
|
|
||||||
<action selector="orderFrontSubstitutionsPanel:" target="-1" id="oku-mr-iSq"/>
|
|
||||||
</connections>
|
|
||||||
</menuItem>
|
|
||||||
<menuItem isSeparatorItem="YES" id="gPx-C9-uUO"/>
|
|
||||||
<menuItem title="Smart Copy/Paste" id="9yt-4B-nSM">
|
|
||||||
<modifierMask key="keyEquivalentModifierMask"/>
|
|
||||||
<connections>
|
|
||||||
<action selector="toggleSmartInsertDelete:" target="-1" id="3IJ-Se-DZD"/>
|
|
||||||
</connections>
|
|
||||||
</menuItem>
|
|
||||||
<menuItem title="Smart Quotes" id="hQb-2v-fYv">
|
|
||||||
<modifierMask key="keyEquivalentModifierMask"/>
|
|
||||||
<connections>
|
|
||||||
<action selector="toggleAutomaticQuoteSubstitution:" target="-1" id="ptq-xd-QOA"/>
|
|
||||||
</connections>
|
|
||||||
</menuItem>
|
|
||||||
<menuItem title="Smart Dashes" id="rgM-f4-ycn">
|
|
||||||
<modifierMask key="keyEquivalentModifierMask"/>
|
|
||||||
<connections>
|
|
||||||
<action selector="toggleAutomaticDashSubstitution:" target="-1" id="oCt-pO-9gS"/>
|
|
||||||
</connections>
|
|
||||||
</menuItem>
|
|
||||||
<menuItem title="Smart Links" id="cwL-P1-jid">
|
|
||||||
<modifierMask key="keyEquivalentModifierMask"/>
|
|
||||||
<connections>
|
|
||||||
<action selector="toggleAutomaticLinkDetection:" target="-1" id="Gip-E3-Fov"/>
|
|
||||||
</connections>
|
|
||||||
</menuItem>
|
|
||||||
<menuItem title="Data Detectors" id="tRr-pd-1PS">
|
|
||||||
<modifierMask key="keyEquivalentModifierMask"/>
|
|
||||||
<connections>
|
|
||||||
<action selector="toggleAutomaticDataDetection:" target="-1" id="R1I-Nq-Kbl"/>
|
|
||||||
</connections>
|
|
||||||
</menuItem>
|
|
||||||
<menuItem title="Text Replacement" id="HFQ-gK-NFA">
|
|
||||||
<modifierMask key="keyEquivalentModifierMask"/>
|
|
||||||
<connections>
|
|
||||||
<action selector="toggleAutomaticTextReplacement:" target="-1" id="DvP-Fe-Py6"/>
|
|
||||||
</connections>
|
|
||||||
</menuItem>
|
|
||||||
</items>
|
|
||||||
</menu>
|
|
||||||
</menuItem>
|
|
||||||
<menuItem title="Transformations" id="2oI-Rn-ZJC">
|
|
||||||
<modifierMask key="keyEquivalentModifierMask"/>
|
|
||||||
<menu key="submenu" title="Transformations" id="c8a-y6-VQd">
|
|
||||||
<items>
|
|
||||||
<menuItem title="Make Upper Case" id="vmV-6d-7jI">
|
|
||||||
<modifierMask key="keyEquivalentModifierMask"/>
|
|
||||||
<connections>
|
|
||||||
<action selector="uppercaseWord:" target="-1" id="sPh-Tk-edu"/>
|
|
||||||
</connections>
|
|
||||||
</menuItem>
|
|
||||||
<menuItem title="Make Lower Case" id="d9M-CD-aMd">
|
|
||||||
<modifierMask key="keyEquivalentModifierMask"/>
|
|
||||||
<connections>
|
|
||||||
<action selector="lowercaseWord:" target="-1" id="iUZ-b5-hil"/>
|
|
||||||
</connections>
|
|
||||||
</menuItem>
|
|
||||||
<menuItem title="Capitalize" id="UEZ-Bs-lqG">
|
|
||||||
<modifierMask key="keyEquivalentModifierMask"/>
|
|
||||||
<connections>
|
|
||||||
<action selector="capitalizeWord:" target="-1" id="26H-TL-nsh"/>
|
|
||||||
</connections>
|
|
||||||
</menuItem>
|
|
||||||
</items>
|
|
||||||
</menu>
|
|
||||||
</menuItem>
|
|
||||||
<menuItem title="Speech" id="xrE-MZ-jX0">
|
|
||||||
<modifierMask key="keyEquivalentModifierMask"/>
|
|
||||||
<menu key="submenu" title="Speech" id="3rS-ZA-NoH">
|
|
||||||
<items>
|
|
||||||
<menuItem title="Start Speaking" id="Ynk-f8-cLZ">
|
|
||||||
<modifierMask key="keyEquivalentModifierMask"/>
|
|
||||||
<connections>
|
|
||||||
<action selector="startSpeaking:" target="-1" id="654-Ng-kyl"/>
|
|
||||||
</connections>
|
|
||||||
</menuItem>
|
|
||||||
<menuItem title="Stop Speaking" id="Oyz-dy-DGm">
|
|
||||||
<modifierMask key="keyEquivalentModifierMask"/>
|
|
||||||
<connections>
|
|
||||||
<action selector="stopSpeaking:" target="-1" id="dX8-6p-jy9"/>
|
|
||||||
</connections>
|
|
||||||
</menuItem>
|
|
||||||
</items>
|
|
||||||
</menu>
|
|
||||||
</menuItem>
|
|
||||||
</items>
|
|
||||||
</menu>
|
|
||||||
</menuItem>
|
|
||||||
<menuItem title="View" id="H8h-7b-M4v">
|
|
||||||
<modifierMask key="keyEquivalentModifierMask"/>
|
|
||||||
<menu key="submenu" title="View" id="HyV-fh-RgO">
|
|
||||||
<items>
|
|
||||||
<menuItem title="Enter Full Screen" keyEquivalent="f" id="4J7-dP-txa">
|
|
||||||
<modifierMask key="keyEquivalentModifierMask" control="YES" command="YES"/>
|
|
||||||
<connections>
|
|
||||||
<action selector="toggleFullScreen:" target="-1" id="dU3-MA-1Rq"/>
|
|
||||||
</connections>
|
|
||||||
</menuItem>
|
|
||||||
</items>
|
|
||||||
</menu>
|
|
||||||
</menuItem>
|
|
||||||
<menuItem title="Window" id="aUF-d1-5bR">
|
|
||||||
<modifierMask key="keyEquivalentModifierMask"/>
|
|
||||||
<menu key="submenu" title="Window" systemMenu="window" id="Td7-aD-5lo">
|
|
||||||
<items>
|
|
||||||
<menuItem title="Minimize" keyEquivalent="m" id="OY7-WF-poV">
|
|
||||||
<connections>
|
|
||||||
<action selector="performMiniaturize:" target="-1" id="VwT-WD-YPe"/>
|
|
||||||
</connections>
|
|
||||||
</menuItem>
|
|
||||||
<menuItem title="Zoom" id="R4o-n2-Eq4">
|
|
||||||
<modifierMask key="keyEquivalentModifierMask"/>
|
|
||||||
<connections>
|
|
||||||
<action selector="performZoom:" target="-1" id="DIl-cC-cCs"/>
|
|
||||||
</connections>
|
|
||||||
</menuItem>
|
|
||||||
<menuItem isSeparatorItem="YES" id="eu3-7i-yIM"/>
|
|
||||||
<menuItem title="Bring All to Front" id="LE2-aR-0XJ">
|
|
||||||
<modifierMask key="keyEquivalentModifierMask"/>
|
|
||||||
<connections>
|
|
||||||
<action selector="arrangeInFront:" target="-1" id="DRN-fu-gQh"/>
|
|
||||||
</connections>
|
|
||||||
</menuItem>
|
|
||||||
</items>
|
|
||||||
</menu>
|
|
||||||
</menuItem>
|
|
||||||
<menuItem title="Help" id="EPT-qC-fAb">
|
|
||||||
<modifierMask key="keyEquivalentModifierMask"/>
|
|
||||||
<menu key="submenu" title="Help" systemMenu="help" id="rJ0-wn-3NY"/>
|
|
||||||
</menuItem>
|
|
||||||
</items>
|
|
||||||
<point key="canvasLocation" x="142" y="-258"/>
|
|
||||||
</menu>
|
|
||||||
<window title="APP_NAME" allowsToolTipsWhenApplicationIsInactive="NO" autorecalculatesKeyViewLoop="NO" releasedWhenClosed="NO" animationBehavior="default" id="QvC-M9-y7g" customClass="MainFlutterWindow" customModule="Runner" customModuleProvider="target">
|
|
||||||
<windowStyleMask key="styleMask" titled="YES" closable="YES" miniaturizable="YES" resizable="YES"/>
|
|
||||||
<rect key="contentRect" x="335" y="390" width="800" height="600"/>
|
|
||||||
<rect key="screenRect" x="0.0" y="0.0" width="2560" height="1577"/>
|
|
||||||
<view key="contentView" wantsLayer="YES" id="EiT-Mj-1SZ">
|
|
||||||
<rect key="frame" x="0.0" y="0.0" width="800" height="600"/>
|
|
||||||
<autoresizingMask key="autoresizingMask"/>
|
|
||||||
</view>
|
|
||||||
</window>
|
|
||||||
</objects>
|
|
||||||
</document>
|
|
||||||
@ -1,14 +0,0 @@
|
|||||||
// Application-level settings for the Runner target.
|
|
||||||
//
|
|
||||||
// This may be replaced with something auto-generated from metadata (e.g., pubspec.yaml) in the
|
|
||||||
// future. If not, the values below would default to using the project name when this becomes a
|
|
||||||
// 'flutter create' template.
|
|
||||||
|
|
||||||
// The application's name. By default this is also the title of the Flutter window.
|
|
||||||
PRODUCT_NAME = star_lock
|
|
||||||
|
|
||||||
// The application's bundle identifier
|
|
||||||
PRODUCT_BUNDLE_IDENTIFIER = com.example.starLock
|
|
||||||
|
|
||||||
// The copyright displayed in application information
|
|
||||||
PRODUCT_COPYRIGHT = Copyright © 2023 com.example. All rights reserved.
|
|
||||||
@ -1,2 +0,0 @@
|
|||||||
#include "../../Flutter/Flutter-Debug.xcconfig"
|
|
||||||
#include "Warnings.xcconfig"
|
|
||||||
@ -1,2 +0,0 @@
|
|||||||
#include "../../Flutter/Flutter-Release.xcconfig"
|
|
||||||
#include "Warnings.xcconfig"
|
|
||||||
@ -1,13 +0,0 @@
|
|||||||
WARNING_CFLAGS = -Wall -Wconditional-uninitialized -Wnullable-to-nonnull-conversion -Wmissing-method-return-type -Woverlength-strings
|
|
||||||
GCC_WARN_UNDECLARED_SELECTOR = YES
|
|
||||||
CLANG_UNDEFINED_BEHAVIOR_SANITIZER_NULLABILITY = YES
|
|
||||||
CLANG_WARN_UNGUARDED_AVAILABILITY = YES_AGGRESSIVE
|
|
||||||
CLANG_WARN__DUPLICATE_METHOD_MATCH = YES
|
|
||||||
CLANG_WARN_PRAGMA_PACK = YES
|
|
||||||
CLANG_WARN_STRICT_PROTOTYPES = YES
|
|
||||||
CLANG_WARN_COMMA = YES
|
|
||||||
GCC_WARN_STRICT_SELECTOR_MATCH = YES
|
|
||||||
CLANG_WARN_OBJC_REPEATED_USE_OF_WEAK = YES
|
|
||||||
CLANG_WARN_OBJC_IMPLICIT_RETAIN_SELF = YES
|
|
||||||
GCC_WARN_SHADOW = YES
|
|
||||||
CLANG_WARN_UNREACHABLE_CODE = YES
|
|
||||||