123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349 |
- // 字母列标
- export function getColumnHeaderCode(len) {
- let tag_arr = [];
- for(let i=0;i<len;i++) tag_arr.push(String.fromCharCode(65+i));
- return tag_arr;
- }
- // 行标
- export function getRowHeaderCode(len) {
- let tag_arr = [];
- for(let i=0;i<len;i++) tag_arr.push(String(1+i));
- return tag_arr;
- }
- //过滤输入空格
- export function filterInput(input) {
- return input.replace(/\s+/g, '');
- }
- //从公式中提取因数
- export function extractFactorsFromFormula(str) {
- let pattern = /[A-Za-z]+\d+/g;
- let factors = str.match(pattern);
- // 提取括号内的内容作为因数
- let parenthesesPattern = /\([^()]+\)/g; // 匹配括号内的内容
- let parenthesesMatches = str.match(parenthesesPattern);
- if (parenthesesMatches) {
- for (let i = 0; i < parenthesesMatches.length; i++) {
- let parenthesesContent = parenthesesMatches[i].slice(1, -1); // 去除括号
- let subFactors = extractFactorsFromFormula(parenthesesContent);
- factors = factors.concat(subFactors);
- }
- }
- return factors.filter ((value, index, self) => self.indexOf(value) === index);
- }
- //根据因数找元素值
- export function findCellByFactor (str) {
- let newStr = splitString(toUpperCase(str));
- let table = document.querySelector('.table');
- let el = table.querySelector("td span[data-rindex='" + newStr[1] + "'][data-cindex='" + newStr[0] + "']") || table.querySelector("td input[data-rindex='" + newStr[1] + "'][data-cindex='" + newStr[0] + "']");
- return el ? (el.innerText||el.value||'') : null;
- }
- //转大写
- export function toUpperCase(str) {
- let uppercaseStr = str.toUpperCase();
- return uppercaseStr;
- }
- //拆分A1为['A','1']
- export function splitString(str) {
- let letter = str.match(/[A-Z]+/)[0];
- let number = str.match(/\d+/)[0];
- return [letter, number];
- }
- //选中整行整列样式
- export function selectMoreCellStyle(e,type=null) {
- let table = document.querySelector('.table');
- resetStyle();
- if($(e.target).hasClass('th-col')) { //点击列
- // 指标列 日期列显示显示有所区分
- const columnIndex = Array.from(e.target.parentNode.children).indexOf(e.target);
- table.rows.forEach((cell,index)=> {
- if(index !==0) {
- if(type === 1) index === 2 ? $(cell.children[columnIndex-1]).addClass('td-col-select') : $(cell.children[columnIndex]).addClass('td-col-select');
- if(type === 2) index === 1 ? $(cell.children[columnIndex-1]).addClass('td-col-select') : $(cell.children[columnIndex]).addClass('td-col-select');
- if(!type) $(cell.children[columnIndex]).addClass('td-col-select');
- }
- })
- }else if($(e.target).hasClass('th-row')) { //点击行
- e.target.parentNode.children.forEach((cell,index)=> {
- if(index !==0) {
- index === 2 ? $(cell).addClass('td-row-select') : $(cell).addClass('td-row-select');
- }
- })
- }
- }
- // 选中格子样式
- export function selectCellStyle(e) {
- let table = document.querySelector('.table');
- resetStyle();
- if (table.querySelectorAll(".td-chose").length == 0) {
- e.target.nodeName==='TD' && $(e.target).addClass("td-chose")
- e.target.parentNode.nodeName==='TD' && $(e.target.parentNode).addClass("td-chose")
- e.target.parentNode.parentNode.nodeName==='TD' && $(e.target.parentNode.parentNode).addClass("td-chose")
- e.target.parentNode.parentNode.parentNode.nodeName==='TD' && $(e.target.parentNode.parentNode.parentNode).addClass("td-chose")
- }
- }
- export function resetStyle() {
- let table = document.querySelector('.table');
- table.querySelectorAll(".td-chose").forEach(el => {
- el.classList.remove('td-chose')
- })
- table.querySelectorAll(".td-col-select").forEach(el => {
- el.classList.remove('td-col-select')
- })
- table.querySelectorAll(".td-row-select").forEach(el => {
- el.classList.remove('td-row-select')
- })
- table.querySelectorAll(".td-relation").forEach(el => {
- el.classList.remove('td-relation')
- })
- }
- //单击聚焦
- export function setFocus(e) {
- if(e.target.nodeName==='TD') {
- let input = e.target.querySelector('input');
- input && input.focus();
- }
- }
- // 插入值或公式有插值后设置背景色
- export function setCellBg(e) {
- e.target.parentNode.nodeName==='TD' && $(e.target.parentNode).addClass("insert")
- e.target.parentNode.parentNode.nodeName==='TD' && $(e.target.parentNode.parentNode).addClass("insert")
- }
- //右键菜单
- export function getRightClickMenu(pos,canEdit=false) {
- let cellMenu = [
- { label: "根据日期选择指标值", key: "choose-target" },
- // { label: "插入指标值", key: "insert-value" },
- { label: "导入日期", key: "insert-date" },
- // { label: "导入指标日期", key: "insert-edb-date" },
- { label: "日期计算", key: "insert-date-calculate" },
- { label: "指标计算",
- key: "insert-edb-calculate",
- children: [
- { label: '累计值转月/季值',source: 1,fromEdbKey:5 },
- { label: '同比值',source: 3,fromEdbKey:6 },
- { label: '同差值',source: 4,fromEdbKey:7 },
- { label: 'N期移动均值',source: 5,fromEdbKey:8 },
- { label: 'N期环比值',source: 6,fromEdbKey:12 },
- { label: 'N期环差值',source: 7,fromEdbKey:13 },
- { label: '升频',source: 8,fromEdbKey:14 },
- { label: '时间移位',source: 10,fromEdbKey:22 },
- { label: '超季节性',source: 11,fromEdbKey:35 },
- { label: '年化值',source: 12,fromEdbKey:52 },
- { label: '降频',source: 9,fromEdbKey:51 },
- { label: '累计值',source: 13,fromEdbKey:62 },
- { label: '指数修匀',source: 15,fromEdbKey:'alpha' },
- { label: '日均值',source: 16,fromEdbKey:75 },
- ]
- },
- { label: "清空", key: "reset" },
- ]
- const menuMap = {
- 'col': [
- { label: "向左插入列", key: "insert-col-left" },
- { label: "向右插入列", key: "insert-col-right" },
- { label: "删除", key: "del" },
- ],
- 'row': [
- { label: "向上插入行", key: "insert-row-up" },
- { label: "向下插入行", key: "insert-row-down" },
- { label: "删除", key: "del" },
- ],
- 'cell': canEdit
- ? [{ label: '编辑',key: 'cell-edit' },...cellMenu]
- : cellMenu
- }
- return menuMap[pos];
- }
- //日期格式识别转换
- export function checkDateFormat(str) {
- const dateRegex = /^(?:(?:19|20)\d\d)([-/.])(0?[1-9]|1[0-2])\1(0?[1-9]|[12][0-9]|3[01])$/;
- //也支持年-月
- const dateMonthRegex = /^(?:(?:19|20)\d\d)([-])(0[1-9]|1[0-2])$/;
-
- if(dateRegex.test(str)) {
- const date = new Date(str);
- if (!isNaN(date.getTime())) {
- const year = date.getFullYear();
- const month = String(date.getMonth() + 1).padStart(2, '0');
- const day = String(date.getDate()).padStart(2, '0');
- return `${year}-${month}-${day}`;
- } else {
- return false;
- }
- } else if(dateMonthRegex.test(str)){
- return str
- } else {
- return false
- }
- }
- /* 根据key找到格子 设置格子样式 */
- export function setRelationStyle(query,classname="td-relation") {
- const { key } = query;
- let table = document.querySelector('.table');
- let el = table.querySelector("td[data-key='" + key + "']");
-
- el.nodeName==='TD' && $(el).addClass(classname)
- }
- //根据cell key找到cell数据
- export function findCellByKey(arr,key) {
- let cell = null;
- for (let i = arr.length - 1; i >= 0; i--) {
- if(!cell) {
- for(let j = arr[i].length-1;j>=0;j--) {
- if(arr[i][j].Uid===key) {
- cell = arr[i][j];
- break
- }
- }
- }
- }
- // console.log(cell)
- return cell
- }
- /* 清空插入单元格重置关联样式 */
- export function resetRelationStyle() {
- let table = document.querySelector('.table');
- table.querySelectorAll(".td-relation").forEach(el => {
- el.classList.remove('td-relation')
- })
- }
- /* 重置右键选择指标时的单元格标识样式 弹窗消失样式就消失 */
- export function resetDialogCellStyle() {
- let table = document.querySelector('.table');
- table.querySelectorAll(".td-choose-insert-target").forEach(el => {
- el.classList.remove('td-choose-insert-target')
- })
- }
- // 根据行头列头位置找key
- export function findCellKeyByFactor(str) {
- let newStr = splitString(toUpperCase(str));
- let table = document.querySelector('.table');
- let el = table.querySelector("td [data-rindex='" + newStr[1] + "'][data-cindex='" + newStr[0] + "']");
- return el ? (el.dataset.key||'') : null;
- }
- /* 判断值是否是一个数字或数字字符串 */
- export function isNumberVal(value) {
- let reg = /^[-]?(?:\d*\.?\d+|\d+%|\d*\.\d+%)$/;
-
- return reg.test(value);
- }
- /* 增加减少小数点位数 */
- export function transDecimalPlace(str,decimalNum) {
- console.log(str,decimalNum)
- let s = str.replace(/%/,''), decimalPlaces = getDecimalPlaces(str);
- //后缀 百分号
- let suffix = str.endsWith('%') ? '%' : '';
- if(decimalPlaces===0) { //整数
- // 补零
- const zerosToAdd = Math.max(0, decimalNum);
- return zerosToAdd > 0
- ? `${s}.${'0'.repeat(zerosToAdd)}${suffix}`
- : `${s}${suffix}`;
- }
- let integerStr = str.split('.')[0],
- decimalStr = str.split('.')[1];
- if(decimalNum>0) {
- return `${s}${'0'.repeat(decimalNum)}${suffix}`
- } else {
- return decimalNum+decimalPlaces > 0
- ? `${integerStr}.${decimalStr.substring(0,decimalNum+decimalPlaces)}${suffix}`
- : `${integerStr}${suffix}`
- }
- }
- /* 计算小数点位数 */
- export function getDecimalPlaces(numStr) {
- // 移除百分号,如果有的话
- numStr = numStr.replace('%', '');
- // 如果没有小数点,说明小数点位数为 0
- if (!numStr.includes('.')) {
- return 0;
- }
- // 获取当前小数点后的位数
- const decimalPlaces = numStr.split('.')[1].length;
- return decimalPlaces;
- }
- /* 格式化单元格值 显示转换 */
- export function transNumPercentType(str,type) {
- console.log(str,type)
- let isPercent = str.endsWith('%'),s=str.replace(/%/,''),decimalPlaces = getDecimalPlaces(str);
-
- if(isPercent && type==='percent') { //百分数转百分
- return str
- }
- if(!isPercent && type==='number') { //数字转数字
- return str
- }
- let num = parseFloat(s)
- if(type==='percent') {
- const percenStr = (num * 100).toFixed(2) + '%';
- return percenStr;
- }else {
- return (num/100).toFixed(2);
- }
- }
- export function transValueFormat(str,{nt,pn}) {
- let str1 = '',str2 = '';
-
- str1 = nt ? transNumPercentType(str,nt) : str;
-
- str2 = pn!==0 ? transDecimalPlace(str1,pn) : str1;
- return str2;
- }
|