更新记录
1.1.0(2024-10-26)
- 新增 根据日程ID 查询当前日程是否存在,检查是否已经被用户删除掉了。
1.0.0(2024-07-23)
首次发布
平台兼容性
Android | Android CPU类型 | iOS |
---|---|---|
适用版本区间:4.4 - 14.0 | armeabi-v7a:未测试,arm64-v8a:未测试,x86:未测试 | 适用版本区间:9 - 17 |
原生插件通用使用流程:
- 购买插件,选择该插件绑定的项目。
- 在HBuilderX里找到项目,在manifest的app原生插件配置中勾选模块,如需要填写参数则参考插件作者的文档添加。
- 根据插件作者的提供的文档开发代码,在代码中引用插件,调用插件功能。
- 打包自定义基座,选择插件,得到自定义基座,然后运行时选择自定义基座,进行log输出测试。
- 开发完毕后正式云打包
付费原生插件目前不支持离线打包。
Android 离线打包原生插件另见文档 https://nativesupport.dcloud.net.cn/NativePlugin/offline_package/android
iOS 离线打包原生插件另见文档 https://nativesupport.dcloud.net.cn/NativePlugin/offline_package/ios
注意事项:使用HBuilderX2.7.14以下版本,如果同一插件且同一appid下购买并绑定了多个包名,提交云打包界面提示包名绑定不一致时,需要在HBuilderX项目中manifest.json->“App原生插件配置”->”云端插件“列表中删除该插件重新选择
Android 和 IOS 日历日程提醒插件
- ios 需要添加上日历权限,再进行云打包,否则使用时出现闪退
"ios" : {
"privacyDescription" : {
"NSCalendarsUsageDescription" : "需要访问日历创建和管理日程事件"
},
"dSYMs" : false
},
1.云打包云端插件之后,引用插件
const plug=uni.requireNativePlugin("html5app-Calendar");
2.在日历中,插入日程和提醒
plug.insertCalendar({
title:"明天去玩",
description:"这是一个奇怪的地方,我要去看看",
startTime:"2024-06-25 10:15:11", //全天时,时间格式是:2024-06-25 00:00:00 2024-06-26 00:00:00
endTime:"2024-06-26 10:15:11",
allday:false, //是否是全天 事件,
repeat:{freq:"WEEKLY",count:2} ,//日程每周重复,一共重复2次 // DAILY:每天重复一次。 WEEKLY:每周重复一次。 MONTHLY:每月重复一次。 YEARLY:每年重复一次。
hasAlarm:true, //是否开启提醒
minutes:[-540,900], //提醒时间。,一天前,
timeZone:"" ,//设置时区,留空使用默认时区
location:"广东省广州市"
},ret=>{
if(ret.code==0)
{
ret.calendatId; //收集成功的日程ID ,可以用于更新或删除该日程
}
});
3.在日历中,根据日程calendatId 更新日程相关内容
plug.updateCalendar({
calendatId:this.calendatId,
title:"我是更新后的",
//description:"这是一个奇怪的地方,我要去看看",
//startTime:"2024-06-25 10:15:11",
//endTime:"2024-06-26 10:15:11"
},ret=>{
});
4.在日历中,根据日程calendatId 更新日程中的提醒时间
plug.updateReminder({
calendatId:this.calendatId,
minutes:[-540,900] //单位是分钟
},ret=>{
});
5.在日历中,根据日程calendatId 删除掉整个日程信息包括重复日程
plug.deleteCalendar({
calendatId:this.calendatId
},ret=>{
});
6.在日历中,根据日程calendatId 删除日程当中的提醒时间
plug.deleteReminder({
calendatId:this.calendatId
},ret=>{
});
7.在日历中,根据日程calendatId 查询当前日程是否存在
plug.queryCalendar({
calendatId:this.calendatId
},ret=>{
});