1
0

index.js 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116
  1. const crcTool = require('../../tools/crc-hash/crc-tool.js')
  2. const asciiCodeTool = require('../../tools/ascii-code/index.js')
  3. const filterCalculator = require('../../tools/filter/index.js')
  4. const smdCodeCalculator = require('../../tools/smd-code/index.js')
  5. const refrigerationCalculator = require('../../tools/refrigeration/index.js')
  6. const reactanceCalculator = require('../../tools/reactance/index.js')
  7. const threePhasePowerCalculator = require('../../tools/three-phase-power/index.js')
  8. const {
  9. getWxApi
  10. } = require('../../utils/base-utils.js')
  11. const crcHandlers = require('./handlers/crc.js')
  12. const asciiCodeHandlers = require('./handlers/ascii-code.js')
  13. const filterHandlers = require('./handlers/filter.js')
  14. const reactanceHandlers = require('./handlers/reactance.js')
  15. const refrigerationHandlers = require('./handlers/refrigeration.js')
  16. const smdCodeHandlers = require('./handlers/smd-code.js')
  17. const threePhasePowerHandlers = require('./handlers/three-phase-power.js')
  18. const TOOL_MODULES = [
  19. { view: 'crc', label: 'CRC与哈希计算', icon: 'icon-crc', iconSrc: '/assets/icons/hash-white.png', calculator: crcTool, handlers: crcHandlers.handlers },
  20. { view: 'asciiCode', label: 'ASCII/数值转换', icon: 'icon-terminal', iconSrc: '/assets/icons/terminal-white.png', calculator: asciiCodeTool, handlers: asciiCodeHandlers.handlers },
  21. { view: 'filter', label: '滤波器计算', icon: 'icon-filter', iconSrc: '/assets/icons/funnel-white.png', calculator: filterCalculator, handlers: filterHandlers.handlers },
  22. { view: 'reactance', label: '电抗计算', icon: 'icon-reactance', iconSrc: '/assets/icons/audio-waveform-white.png', calculator: reactanceCalculator, handlers: reactanceHandlers.handlers },
  23. { view: 'smdCode', label: '贴片电阻/容代码', icon: 'icon-smd', iconSrc: '/assets/icons/microchip-white.png', calculator: smdCodeCalculator, handlers: smdCodeHandlers.handlers },
  24. { view: 'refrigeration', label: '制冷计算', icon: 'icon-snow', iconSrc: '/assets/icons/snowflake-white.png', calculator: refrigerationCalculator, handlers: refrigerationHandlers.handlers },
  25. { view: 'threePhasePower', label: '三相功率计算', icon: 'icon-three-phase', iconSrc: '/assets/icons/zap-white.png', calculator: threePhasePowerCalculator, handlers: threePhasePowerHandlers.handlers }
  26. ]
  27. const TOOL_ENTRIES = TOOL_MODULES.map((item) => ({
  28. icon: item.icon,
  29. iconSrc: item.iconSrc,
  30. label: item.label,
  31. view: item.view
  32. }))
  33. function getToolEntries() {
  34. return TOOL_ENTRIES.map((item) => ({ ...item }))
  35. }
  36. function isToolView(view) {
  37. return TOOL_ENTRIES.some((item) => item.view === view)
  38. }
  39. function getToolEntry(view) {
  40. return TOOL_ENTRIES.find((item) => item.view === view) || null
  41. }
  42. function getToolTitle(view) {
  43. const entry = getToolEntry(view)
  44. return entry ? entry.label : ''
  45. }
  46. function createToolInitialState() {
  47. return TOOL_MODULES.reduce((state, item) => {
  48. if (!item.calculator || typeof item.calculator.createInitialState !== 'function') return state
  49. return {
  50. ...state,
  51. ...item.calculator.createInitialState()
  52. }
  53. }, {})
  54. }
  55. const toolNavigation = {
  56. getToolEntry,
  57. getToolEntries,
  58. getToolTitle,
  59. isToolView
  60. }
  61. function copyToolResult(event) {
  62. const value = event && event.currentTarget && event.currentTarget.dataset
  63. ? event.currentTarget.dataset.value
  64. : ''
  65. const text = String(value === undefined || value === null ? '' : value).trim()
  66. if (!text || text === '--') return
  67. const wxApi = getWxApi()
  68. if (typeof wxApi.setClipboardData !== 'function') {
  69. if (this.pageToast) this.pageToast.show('当前环境不支持复制', 'error')
  70. return
  71. }
  72. wxApi.setClipboardData({
  73. data: text,
  74. fail: () => {
  75. if (this.pageToast) this.pageToast.show('复制失败', 'error')
  76. },
  77. success: () => {
  78. if (this.pageToast) this.pageToast.show('已复制')
  79. }
  80. })
  81. }
  82. function createToolHandlers() {
  83. return TOOL_MODULES.reduce((handlers, item) => {
  84. if (!item.handlers) return handlers
  85. return {
  86. ...handlers,
  87. ...item.handlers
  88. }
  89. }, {})
  90. }
  91. const toolPageHandlers = {
  92. copyToolResult,
  93. ...createToolHandlers()
  94. }
  95. module.exports = {
  96. createToolInitialState,
  97. toolNavigation,
  98. toolPageHandlers
  99. }