大象笔记

知者行之始,行者知之成

SuiteCRM 二次开发:合同金额与默认货币合同金额的区别

在通过 logic hook 开发 SuiteCRM 合同回款率计算功能时,遇到一个疑问: 为何合同模块有两个合同金额字段?在计算回款率时,我应该使用哪个作为合同金额计算的参考呢? total_contract_value:合同金额 total_contract_value_usdollar:合同金额(默认货币) 这两个字段在数据库的 aos_contracts 表中就能看到,在 admin 的工作室功能中也能看到。 同时,可以看到所有钱相关的字段,都是用了两个字段表示。即便加上了更多的币种,比如人民币,美元,欧元等,也是这两个字段。有 usdollar 后缀的字段,就是默认货币。 实测 ...

阅读全文...

SuiteCRM 二次开发:基于 logic hook 实现合同回款率的计算

SuiteCRM 的这套 hook 机制还是挺灵活的。就是文档有的少,大部分靠摸索。 部署时,只能在工作日晚上,或者周末没人使用时才能部署。异常痛苦。 关联记录存储时相关的 hook 这个属于 Module Hooks,即模块级的 Hook。 after_relationship_add after_relationship_delete 除了关系的添加和删除,实际上应该还有收款记录的值修改需要监听。 after_save 看起来,在合同模块添加 Hook,不如在收款记录模块添加 Hook 更方便管理。因为统计函数能够复用。 后续补充: 这里还是想简单了。关系的添加和收款金额变更这两种 ...

阅读全文...

SuiteCRM 二次开发:创建 logic hook 实现自定义逻辑

昨天看了一天 SuiteCRM logic hook 的资料,并搜索了 github 上能搜到的所有代码。 但是,感觉效果并不好,公开出来的代码太少,只能零散的学到一些小技巧。 于是,我决定直接在测试环境中通过调试来摸索一番。 修改 logic_hooks.php 例如,我想在客户新关联一个联系人时,自动触发一段 logic hook 逻辑代码。 那么,我需要进入到目录 custom/modules/Contacts 打开 logic_hooks.php, 在最后添加上自己定义的逻辑,修改完后,如下: <?php // Do not store anything in this fil ...

阅读全文...

SuiteCRM 线上代码用 git 管理

先吐个槽,我发现让销售用上 CRM 真是一件难事。昨天忍不住爆了粗口,感觉没必要。 大家都在装糊涂,或者为自己那点利益使唤别人,就由着他们吧。少说话,多干活。经验是自己的。 言归正传,我发现 SuiteCRM 中新建了模块,或者修改了内置模块之后。SuiteCRM 的代码也会随之更改,即生成了新的 model 类型。(不得不说,PHP 确实是世界上最好的语言) 所以,除了对线上数据库做好备份之外,还需要对线上的代码做个备份。 git 代码管理的必要性 我发现在变更了大量默认配置之后,线上日志中,出现了大量的报错日志。基本都是跟新增的模块对应的 SQL 查询相关。我非常害怕哪天这个系统崩溃了, ...

阅读全文...

哎呀爽啦,Obsidian 看板插件完美实现个人项目管理

Obsidian 大名早有耳闻,公众号天天给我推送 Obsidian 的文章,但是我一直没有尝试。 之前使用的项目管理方式 Trello:trello 中记录 todo,doing,done,资料等记录。 VIM Markdown Wiki 文件:记录一些笔记,方便整理思路 但是,这种方式最近觉得有些不便: trello 被和谐了,即便 xx 访问,也非常卡顿。而且在 trello 中记录一些重要资料,很容易因为手误被删除,而且无法回滚。其次,多看板间切换麻烦,毕竟网络卡顿,体验不好。 纯 markdown 文件中,记录 todo 内容多了,超过 100 条,后面再添加新条目,就非常 ...

阅读全文...

2014 服务器迁移计划

虽然当前的服务器今年 11 月才会到期(还有7/8个月),但是由于近期阿里云搞活动,忍不住还是入手了一台。 参考: 堪称良心云,老客户不再是狗,199 入手了阿里云2核4G 5M 带宽服务器 我想把目前的服务器腾出来,跑几个小模型试试。 于是,服务器的迁移计划就提上了日程。里面的乱七八糟的服务太多了,迁移是个大工程。 本来这个计划是躺在本地笔记里的,但是发现实在是懒得处理,不如发布到博客上,还经常看到,一点点处理吧。 TODO 新建一个用户 安装 Nginx 安装 Mysql 8 wordpress 相关的网站代码打包备份到本地电脑上。不再线上支持。 wordpress 站点 nginx 配 ...

阅读全文...

SuiteCRM 设置负责人时显示全名,而不是 user_name

在使用中文 SuiteCRM 时,有个不友好的地方,例如, 新建客户资料时,在选择要分配的负责人后,字段里会显示负责人的 user_name, 而不是中文名字。 这对用户来说,体验非常不好。 本以为需要修改 PHP 代码,实际上不需要,修改一下配置即可。 解决方法 这里涉及到两个地方的设置: 管理员的全局设置:系统设置,勾选“负责人字段显示全名” 每个人的个人设置:在高级选项卡中,勾选“负责人字段显示全名” 参考 详细的解释参考这里: https://community.suitecrm.com/t/i-want-to-show-the-first-name-and-last-name-i ...

阅读全文...

堪称良心云,老客户不再是狗,199 入手了阿里云2核4G 5M 带宽服务器

早上收到阿里云的推广短信,说有 99 一年的 2核2G 3M的服务器优惠活动,而且还可以享受3次这个续费价格。活动截止 2014 年 3 月底。 说实话,99 一年我并没有心动,心动的是可以续费这么多次。 正好目前在用的这个服务器,今年,即 2014 年 11 月就到期了,我正愁每年续费的问题。现在续费一次是 2000 多一年,配置为 2c4g 3M 带宽。我觉得非常不合算。 于是赶紧打开了阿里云官网看看具体的活动细节。活动地址: 阿里云ECS11月销量王 99元/年 跳过前面的幻兽帕鲁服务器活动,下面就是 99 每年的活动。 没想到发现了另一个更适合我的活动,就是这个2核4G 5M 带宽服 ...

阅读全文...

升级 rust 到最新版本

今天在安装 rust loco-cli 时,发现系统上的 rust 版本太低,无法安装相关依赖: package clap_derive v4.5.0 cannot be built because it requires rustc 1.74 or newer, while the currently active rustc version is 1.73.0 看了一下版本,确实是 1.73.0 版本。 $ cargo --version cargo 1.73.0 (9c4383fb5 2023-08-26) 升级命令 rustup update 执行之后,就能看到所有 rust ...

阅读全文...

基于用友 U8 API 实现手持 Android 设备上的库存管理

需求背景 公司内部有一套用友 U8 的 ERP 系统,里面有仓库库存管理的功能。 库管人员希望能够加上手持 PDA (比如这个商米的设备:https://www.sunmi.com/zh-CN/v2s/),或者手机 App 扫码入库/打印标签的功能。 但是本地代理公司的开发费用非常离谱,所以公司考虑内部实现这个功能。于是查了一下 U8 相关的接口方案。 网上搜索了一下,资料真是少,而且这个行业非常 low,大部分能看到文档都是软文,和误导,让你去加他们联系方式,获取一个他们封装好的接口。问题是这么敏感的内部数据,怎么敢使用这类小作坊的接口层(涉及到账号密码的提交)。 API 接入方式 1: O ...

阅读全文...

企业内部系统的统计报表实现方案选型

今年的工作重点变成了公司内部的企业数字化开发。说得更具体点,就是搞一些: 销售管理 CRM 仓库管理 生产计划任务管理 各种 ERP OA 集采平台数据打通 ... 任务繁杂,需求不明确,没有人手。看起来无比头疼,非常不想介入这些事情。因为最近看的一本书里说的非常有道理,如果一个项目对于最终客户体验没有任何改善,那么就不要去自己实现,例如,内部的这些信息化系统。 牢骚这么多,进入正题。 需求 将 CRM 中的合同等数据做统计报表,分行业,分产品,分销售部门/个人统计,方便老板及管理层查看。 为何要选型 由于是使用了开源的 CRM,所以如果要在上面直接二次开发一些统计功能页面,实际上,梳理代 ...

阅读全文...

升级 Android App API 级别

有近一年没有打开 Google Play Console 了,最近打开,发现一堆警告信息,大部分是: 请在 2023年8月31日之前更新您的目标 API 级别,以发布应用的更新 警告内容 我们检测到您的应用以旧版 Android 为目标平台。为了向用户提供安全可靠的使用体验,Google Play 要求所有应用都必须符合目标 API 级别要求。 自 2023年8月31日起,如果您的目标 API 级别不是在最新 Android 版本发布日期前 1 年内推出的,您将无法更新应用。 如需继续更新应用,请确保您的应用以 Android 13(API 级别 33)为目标平台。 目前最新的 andro ...

阅读全文...