Sending MailApp mail provided

such a question: There is a code that sends an email with the data of the cell “var RANGE” Under the condition “var check” > 10 in the “if” function What needs to be done to:

  1. The “var check” condition did not parse a single cell, but a range. (Just write Q123:Q126, it won’t work, the script is not executed) and the condition should not be >10, but equal to =10 since the trigger runs the function every day and checks the table.

  2. If the number 10 is in the “var check” range, then the entire line should be sent by email. If it doesn’t work out, then at least do it like this>

  3. “var RANGE” make it possible to selectively take cells (ex. B121:N129, R123:T129)

Can i get some advice?

var ID = "1sBtjJ9x4IKwb9GKu3x3DwoNWTxPej7HJWk5ze8aK"; //speadsheet id
var EMAIL = "[email protected]"; //email 
var RANGE = "Warranty_2021!B121:n129"; //data range to send
var check = "Warranty_2021!Q123:Q123"; //parametr
var text = "Servis"; //subject


function sendData() {
  var spreadsheet = SpreadsheetApp.openById(ID);
  var data = spreadsheet.getRangeByName(RANGE).getValues();
  var message = {};
  if (SpreadsheetApp.openById(ID).getRangeByName(check).getValues()>10){ //condition
  message.subject = "[La Test] " + text;
  message.to = EMAIL;
  message.htmlBody = dataToHtmlTable_(data) +
    "<br><br>[IT care you ;)]";
  MailApp.sendEmail(message);
  }
  let quota = MailApp.getRemainingDailyQuota();
  console.log(quota)
}

Array.prototype.datesToString = function(){
  return this.map(function(row){
    return row.map(function(cell){
      return cell && cell.getTime ? Utilities.formatDate(cell, Session.getScriptTimeZone(), "yyyy-MM-dd ") : cell;
    });
  });
}


function dataToHtmlTable_(data){
  return JSON.stringify(data, null, "  ")
  .replace(/^[/g, "<table>")
  .replace(/]$/g, "</table>")
  .replace(/^ss[$/mg, "<tr>")
  .replace(/^ss],{0,1}$/mg, "</tr>")
  .replace(/^s{4}"{0,1}(.*?)"{0,1},{0,1}$/mg, "<td>$1</td>");
}

is it possible to let different entry package to different output path in webpack 5

I am using webpack to package a google chrome extension, I want to keep the folder structure in the dist folder. for example, I want to package all popup resource in the dist/popup/*, this is my config right now:

const path = require('path');
const webpack = require( 'webpack' );
const MiniCssExtractPlugin = require( 'mini-css-extract-plugin');
const HtmlWebpackPlugin = require( 'html-webpack-plugin');
const CopyPlugin = require("copy-webpack-plugin");

module.exports = {
  entry : {
    popup : './src/popup/' 
  } ,
  resolve: {
    alias: {
        // https://stackoverflow.com/questions/50805384/module-not-found-error-cant-resolve-vue-path-not-correct
        vue: 'vue/dist/vue.esm-bundler.js'
    },
  },
  output : {
    path : path.resolve(__dirname, '../../bundle') ,
    filename : '[path]/[name].js'
  },
  module : {
    rules : [
      {
        test : /.js$/ ,
        exclude : [ /node_modules(?!(/|\?\)(translation.js|selection-widget|connect.io|chrome-env)1)/ ] ,
        loader : 'babel-loader'
      } ,
      {
        test: /.css$/i,
        use: [MiniCssExtractPlugin.loader, "css-loader"],
      },
      {
        test : /.(scss)$/ ,
        use: [MiniCssExtractPlugin.loader, 'css-loader', 'sass-loader']
      }
    ]
  },
  plugins : [
    new CopyPlugin({
      patterns: [
        { from: "src/manifest.json", to: "manifest.json" },
        { from: "src/resource/image", to: "resource/image" },
      ],
    }),
    new MiniCssExtractPlugin({
      filename: "[name].css",
      chunkFilename: "[id].css",
    }),
    new HtmlWebpackPlugin({
      filename: 'popup.html',
      template: 'src/popup/index.html'
    }),
    new webpack.DefinePlugin({
      __VUE_OPTIONS_API__: false,
      __VUE_PROD_DEVTOOLS__: false,
    }),
  ]
};

I have tried to tweak the output filename like this:

filename : '[path]/[name].js'

seems did not work. I am searching from google and did not found any suggestion. Is it possible to do like this? or different entry with different dist folder.

Three.Js Whenever i load an obj with objloader extra vertices are added to my object even after using indexed geometry

Hello so as the title says whenever i load an obj file with obj loader along with indexed geometry extra vertices are added to my object and i cant figure out why.

For example when i load my obj without indexed geometry the vertices are the same as the faces of the object ( from what i read this is because of triangle soup) after using BufferGeometryUtils.mergeVertices and then Computing Vertex Normals the vertice count went down almost to the original but not quite.

This is how i use obj loader

loader= new OBJLoader()
var textureLoader = new THREE.TextureLoader(loadingManager);
var map = textureLoader.load('Castle.jpg'); 
var material = new THREE.MeshPhysicalMaterial({map: map, vertexColors: true});

loader.load( 'Castle.obj', function ( obj ) {
    
    obj.children[0].geometry = BufferGeometryUtils.mergeVertices(obj.children[0].geometry);     
    obj.children[0].computeVertexNormals();

    obj.traverse( function ( node ) {

        if ( node.isMesh ) 
        {
        node.material = material;
        
        }

      } );
    scene.add(obj)
} 
);

My 2 obj files which i work with have these stats
Castle.obj
Vertices :220.153
On three.js 270.532

Ball.obj
Vertices: 95.213
on three.js 123.357

The face count remains the same. Am i doing something wrong? If i use the deprecated Geometry everything works properly however since it’s deprecated i dont know if it’s the right thing to do. Im on version 0.136

Best regards

is there better way coverting html string to DOM?

<div class="row data">
  <div class="subdiv">
    <div class="check"><input type="checkbox" name="buy" value="260" checked="" onclick="javascript:basket.checkItem();">&nbsp;</div>
    <div class="img"><img src="./img/basket1.jpg" width="60"></div>
    <div class="pname">
      <span>TX2</span>
    </div>
  </div>
  <div class="subdiv">
    <div class="num">
      <div class="updown">
        <input type="text" name="p_num1" id="p_num1" size="2" maxlength="4" class="p_num" value="2" onkeyup="javascript:basket.changePNum(1);">
        <span onclick="javascript:basket.changePNum(1);"><i class="fas fa-arrow-alt-circle-up up"></i></span>
        <span onclick="javascript:basket.changePNum(1);"><i class="fas fa-arrow-alt-circle-down down"></i></span>
      </div>
    </div>
  </div>
  <div class="subdiv">
    <div class="basketcmd"><a href="javascript:void(0)" class="abutton" onclick="javascript:basket.delItem();">삭제</a></div>
  </div>
</div>

I saw the way using DOMParser().parseFromString, but this solution requires me to convert html code into one line string. Is there better way to convert or skills to make html code to string easily?

my final goal is to use appendChild() so that I can have many “row data” class div. which requires me to make html code to DOM.

How to update a value in a complex fhirBundle JSON?

Given a bewildering fhir document like https://raw.githubusercontent.com/Notarise-gov-sg/api-notarise-healthcerts/master/test/fixtures/v2/pdt_art_with_nric_unwrapped.json

I need to update the part the JSON from { "id": "NRIC-FIN", "value": "S9098989Z" } to { "id": "NRIC-FIN", "value": "foobar" } and then emit the whole JSON again with that change.

I just about know how to access the value.

const fs = require("fs");
let rawdata = fs.readFileSync("pdt_art_with_nric_unwrapped.json");
let art = JSON.parse(rawdata);

let nric = art.fhirBundle.entry
  .flatMap((entry) => entry.resource)
  .find((entry) => entry.resourceType === "Patient")
  .identifier.find((entry) => entry.id === "NRIC-FIN").value;

console.log(nric);

Though I am puzzled how to update this value since it’s so difficult to access. Am I missing a trick? I don’t want to use regex btw!

apexcharts range bars not displayed correctly

I’m trying to display a Range Bar Chart with AppexCharts for team due date tasks (2 tasks or above).

every task can have multiple bars
if the number of bars in each task is more than 2 the bars of each task get into each other
please take a look at this example that can explain my point clearly .

Thank you .

var options = {
          series: [
             {
            name: 'task1',
            data: [
                {
                x: 'Team Health',
                y: [
                  new Date('2021-03-01').getTime(),
                  new Date('2021-03-02').getTime()
                ]
              },
                   {
                x: 'Team Health',
                y: [
                  new Date('2021-03-02').getTime(),
                  new Date('2021-03-05').getTime()
                ]
              },
                 {
                x: 'Team Health',
                y: [
                  new Date('2021-03-01').getTime(),
                  new Date('2021-03-07').getTime()
                ]
              },
                   {
                x: 'Team Health',
                y: [
                  new Date('2021-03-02').getTime(),
                  new Date('2021-03-08').getTime()
                ]
              },
                    {
                x: 'Team Health',
                y: [
                  new Date('2021-03-01').getTime(),
                  new Date('2021-03-05').getTime()
                ]
              },
        
            ]
          },
            {
            name: 'task2',
            data: [
                {
                x: 'Team Health',
                y: [
                  new Date('2021-03-01').getTime(),
                  new Date('2021-03-10').getTime()
                ]
              },
            
                 {
                x: 'Team Health',
                y: [
                  new Date('2021-03-01').getTime(),
                  new Date('2021-03-03').getTime()
                ]
              },
       
                    {
                x: 'Team Health',
                y: [
                  new Date('2021-03-3').getTime(),
                  new Date('2021-03-08').getTime()
                ]
              },
        
            ]
          },
    
        ],
          chart: {
       height:400,
          type: 'rangeBar'
        },
        plotOptions: {
          bar: {
            horizontal: true,
            barHeight: '80%',
            rangeBarOverlap: false,
      
           columnWidth: '10%',
          }
        },
        xaxis: {
          type: 'datetime',
             position: 'top',
           
        },
        stroke: {
          width: 1
        },
        fill: {
          type: 'solid',
          opacity: 0.6
        },
        legend: {
          position: 'top',
          horizontalAlign: 'center'
        }
        };

Canvas zoom to any coordinates

First of all, I did tons of research but I only found this topic related to Mouse positions.

I have a canvas element and I’m doing some zooming stuff with it (while clicking, scrolling etc.)

This function below shows how the zooming works.

    zoom(clicks) {;
        var pt = this.ctx.transformedPoint(this.X, this.Y);
        this.ctx.translate(pt.x, pt.y);
        var factor = Math.pow(this.scaleFactor, clicks);
        this.ctx.scale(factor, factor);
        
        this.totalzoom *= factor;
        this.ctx.translate(-pt.x, -pt.y);
        this.reDraw();
    }

X means mouseX

Y means mouseY

this.X = evt.offsetX;
this.Y = evt.offsetX;

These are working really fine until I want to use this functions to zoom only to a unique position. I edited my code like this to make it work somehow:

    zoomToItem(x,y){

        var pt = this.ctx.transformedPoint(x, y);
        this.ctx.translate(pt.x, pt.y);
        var factor = Math.pow(this.scaleFactor, 10);
        this.ctx.scale(factor, factor);
        
        this.totalzoom *= factor;
        this.ctx.translate(-pt.x, -pt.y);
        this.reDraw();
    }

The real problem is that in the original view the coordinates what I give is proper, but as I mentioned I scale the image to fit in the canvas, so the given coordinates won’t be proper anymore.

Here’s an example what I tried:

let transform = this.Core.Draw.ctx.getTransform();

let X = (this.item[i].x - this.rects.left - transform.e) / transform.a; 
let Y = (this.item[i].y - this.rects.top - transform.f) / transform.d;

this.zoomToItem(X,Y);

Trying to submit 2 forms(a form and a image upload) on flask

I have two forms, I need a single submit button for two forms(a normal form and a upload). I’ve tried to use javascript but It would only upload the 2nd form which is the image upload. I’m sorry if the code looks weird as I’m still new to it.

{% extends "Base.html" %}
{% block title %}title{% endblock %}

{% block content %}
{% from "includes/_formHelper.html" import render_field %}
<div class="container" style="width:50em;">
<h1 class="display-4">Create Products</h1>
<form method="POST" action=" " id="firstform">
  <div class="form-group">
    {{ render_field(form.product_name, class="form-control") }}
  </div>
  <div class="form-group">
    {{ render_field(form.brand, class="form-control") }}
  </div>
  <div class="form-group">
    {{ render_field(form.category, class="form-control") }}
  </div>
  <div class="form-group">
    {{ render_field(form.quantity, class="form-control") }}
  </div>
    </form>
<form method="post" action="/" enctype="multipart/form-data" id="secondform">
    <h4>Select a file to upload</h4>
        <dl>
            <p>
                <input type="file" name="file" class="form-control" required>
            </p>
        </dl>
    </form>
  <br>
    <button type="submit" value="Submit" class="btn btn-primary" onclick="submitForms()">Save Products</button>
</div>
<style>
  h1{
  text-align:center;
  }
  p{
  color:#212529;
  font-size:16px;
  }
  h4{
  color:#212529;
  font-size:16px;
  }
</style>
{% endblock %}

JavaScript:

<script language="javascript">
submitForms = function(){
  document.getElementById("firstform").submit();
  document.getElementById("secondform").submit();
}
</script>

Why java script toggle text loose functionality after i refresh the page

To conceal the pointless columns, I`m the usage of a javascript toggle textual content on my gallery filter, which goes flawlessly. However, the columns amplify each time I refresh the page, and I need to click on display all then conceal all to get it to work. And the cause I did rows is if I insert the showmore identityentification withinside the center of the columns, when I press display all, they’ll show one column on every line, but on this technique all of the columns will show normally. I attempted converting the show cost withinside the javascript to many different values, however it’s miles nevertheless now no longer running properly. Do you’ve got got any pointers for the way to clear up this?

   function togglesec1() {
    var showMoreText = document.getElementById("showmore");  
    var buttonText = document.querySelector("#moreBtn p");
    var moreIcon = document.querySelector("#moreBtn img");
    
    if (startsec.style.display === "none") {
      showMoreText.style.display = "none";
      startsec.style.display = "inline";
      buttonText.innerHTML = "Show More";    
      buttonText.classList.remove('lesser');
      moreIcon.classList.remove('lesser');
    } else {
      showMoreText.style.display = "inline";
      startsec.style.display = "none";
      buttonText.innerHTML = "Show Less";
      buttonText.classList.add('lesser');
      moreIcon.classList.add('lesser');
    }
  }
 <head>
  <link rel="shortcut icon" href="./images/favicon.ico"      type="image/vnd.microsoft.icon" />
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>    
    <link  href="https://cdn.jsdelivr.net/npm/[email protected]/dist/css/bootstrap.min.css" rel="stylesheet" integrity="sha384-1BmE4kWBq78iYhFldvKuhfTAU6auU8tT94WrHftjDbrCEXSU1oBoqyl2QvZ6jIW3" crossorigin="anonymous">
 </head>

<body>
<section id="work">
       <div class="container-fluid clientbox text-center py-5">
         <div class="row">
              <div class="col-12 col-md-12 col-lg-12 text-center">
         <ul>
           <li class="list-inline-item active" data-filter="all">A</li>
           <li class="list-inline-item" data-filter="B">B</li>
           <li class="list-inline-item" data-filter="C">C</li>
           <li class="list-inline-item" data-filter="D">D</li>
           <li class="list-inline-item" data-filter="M">M</li>
           <li class="list-inline-item" data-filter="UI">U</li>
           <li class="list-inline-item" data-filter="CO">CC</li>
         </ul>
        </div>
        </div>
          <div class="row g-0">

            <div class="clients C col-6 col-md-4 col-lg-3">
              <a href="#">
                <figure class="client-container">
                  <img class="img-fluid brand-img" src="https://toppng.com/uploads/preview/book-11549420966kupbnxvyyl.png" alt="Logo">
                  <figcaption class="product-desc"><P>C</P></figcaption>
                  <figcaption class="product-desc2"><p>H</p></figcaption>
                </figure>
              </a>
            </div>
            <div class="clients B D C CC col-6 col-md-4 col-lg-3">
              <a href="#">
                <figure class="client-container">
                  <img class="img-fluid brand-img" src="https://w7.pngwing.com/pngs/36/268/png-transparent-ballpoint-pen-stylus-fountain-pen-waterman-pens-pen-pen-advertising-rollerball-pen.png" alt="Logo">
                  <figcaption class="product-desc"><P>b</P></figcaption>
                  <figcaption class="product-desc2"><p>k</p></figcaption>
                </figure>
              </a>
            </div>
            <div class="clients B C D M U CC col-6 col-md-4 col-lg-3">
              <a href="#">
                <figure class="client-container">
                  <img class="img-fluid brand-img" src="https://toppng.com/uploads/preview/black-electric-guitar-11530936970df8gvueqvz.png" alt="Logo">
                  <figcaption class="product-desc"><P>n</P></figcaption>
                  <figcaption class="product-desc2"><p>P</p></figcaption>
                </figure>
              </a>
            </div>
            <div class="clients B C D CC col-6 col-md-4 col-lg-3">
              <a href="#">
                <figure class="client-container">
                  <img class="img-fluid brand-img" src="https://toppng.com/uploads/preview/book-11549420966kupbnxvyyl.png" alt="Logo">
                  <figcaption class="product-desc"><P>B</P></figcaption>
                  <figcaption class="product-desc2"><p>G</p></figcaption>
                </figure>
              </a>
            </div>
            </div>
            <div id="startsec"></div>
            <div id="showmore">
            <div class="row g-0">
            <div class="clients B CC col-6 col-md-4 col-lg-3">
              <a href="#">
                <figure class="client-container">
                  <img class="img-fluid brand-img" src="https://toppng.com/uploads/preview/black-electric-guitar-11530936970df8gvueqvz.png" alt="Logo">
                  <figcaption class="product-desc"><P>N</P></figcaption>
                  <figcaption class="product-desc2"><p>g</p></figcaption>
                </figure>
              </a>
            </div>
            <div class="clients D B C M col-6 col-md-4 col-lg-3">
              <a href="#">
                <figure class="client-container">
                  <img class="img-fluid brand-img" src="https://w7.pngwing.com/pngs/454/512/png-transparent-red-and-white-guitar-red-white-guitar-red-guitar-folk-guitar-thumbnail.png" alt="Logo">
                  <figcaption class="product-desc"><P>N</P></figcaption>
                  <figcaption class="product-desc2"><p>s</p></figcaption>
                </figure>
              </a>
            </div>
            <div class="clients B UI col-6 col-md-4 col-lg-3">
              <a href="#">
                <figure class="client-container">
                  <img class="img-fluid brand-img" src="https://esquilo.io/png/thumb/OQQMxyuwyKmDwp0-Musical-Vector-Acoustic-Guitar-PNG.png" alt="Logo">
                  <figcaption class="product-desc"><P>BS</P></figcaption>
                  <figcaption class="product-desc2"><p>l</p></figcaption>
                </figure>
              </a>
            </div>
            <div class="clients CC col-6 col-md-4 col-lg-3">
              <a href="#">
                <figure class="client-container">
                  <img class="img-fluid brand-img" src="https://toppng.com/uploads/preview/book-11549420966kupbnxvyyl.png" alt="Logo">
                  <figcaption class="product-desc"><P>CN</P></figcaption>
                  <figcaption class="product-desc2"><p>C</p></figcaption>
                </figure>
              </a>
            </div>
            <div class="clients D col-6 col-md-4 col-lg-3">
              <a href="#">
                <figure class="client-container">
                  <img class="img-fluid brand-img" src="https://toppng.com/uploads/preview/black-electric-guitar-11530936970df8gvueqvz.png" alt="Logo">
                  <figcaption class="product-desc"><P>d</P></figcaption>
                  <figcaption class="product-desc2"><p>T</p></figcaption>
                </figure>
              </a>
            </div>
            <div class="clients B D col-6 col-md-4 col-lg-3">
              <a href="#">
                <figure class="client-container">
                  <img class="img-fluid brand-img" src="https://w7.pngwing.com/pngs/454/512/png-transparent-red-and-white-guitar-red-white-guitar-red-guitar-folk-guitar-thumbnail.png" alt="Logo">
                  <figcaption class="product-desc"><P>Bl</P></figcaption>
                  <figcaption class="product-desc2"><p>E</p></figcaption>
                </figure>
              </a>
            </div>
            <div class="clients B D CC col-6 col-md-4 col-lg-3">
              <a href="#">
                <figure class="client-container">
                  <img class="img-fluid brand-img" src="https://toppng.com/uploads/preview/book-11549420966kupbnxvyyl.png" alt="Logo">
                  <figcaption class="product-desc"><P>BN</P></figcaption>
                  <figcaption class="product-desc2"><p>S</p></figcaption>
                </figure>
              </a>
            </div>
            <div class="clients B C D M col-6 col-md-4 col-lg-3">
              <a href="#">
                <figure class="client-container">
                  <img class="img-fluid brand-img" src="https://w7.pngwing.com/pngs/454/512/png-transparent-red-and-white-guitar-red-white-guitar-red-guitar-folk-guitar-thumbnail.png" alt="Logo">
                  <figcaption class="product-desc"><P>B</P></figcaption>
                  <figcaption class="product-desc2"><p>I</p></figcaption>
                </figure>
              </a>
            </div>
            <div class="clients B M C D CC col-6 col-md-4 col-lg-3">
              <a href="#">
                <figure class="client-container">
                  <img class="img-fluid brand-img" src="https://w7.pngwing.com/pngs/454/512/png-transparent-red-and-white-guitar-red-white-guitar-red-guitar-folk-guitar-thumbnail.png" alt="Logo">
                  <figcaption class="product-desc"><P>N</P></figcaption>
                  <div class="product-desc2"><p>o</p></div>
                </figure>
              </a>
            </div>
            <div class="clients C B col-6 col-md-4 col-lg-3">
              <a href="#">
                <figure class="client-container">
                  <img class="img-fluid brand-img" src="https://encrypted-tbn0.gstatic.com/images?q=tbn:ANd9GcSHo3btqZiiOgTrKCGihDfnm9V5va87up2aeg&usqp=CAU" alt="Logo">
                  <figcaption class="product-desc"><P>CAG</P></figcaption>
                  <figcaption class="product-desc2"><p>Jr</p></figcaption>
                </figure>
              </a>
            </div>
            <div class="clients B col-6 col-md-4 col-lg-3">
              <a href="#">
                <figure class="client-container">
                  <img class="img-fluid brand-img" src="https://encrypted-tbn0.gstatic.com/images?q=tbn:ANd9GcSHo3btqZiiOgTrKCGihDfnm9V5va87up2aeg&usqp=CAU" alt="Logo">
                  <figcaption class="product-desc"><P>Brl</P></figcaption>
                  <figcaption class="product-desc2"><p>Sl</p></figcaption>
                </figure>
              </a>
            </div>
          
            <div class="clients B CC col-6 col-md-4 col-lg-3">
              <a href="#">
                <figure class="client-container">
                  <img class="img-fluid brand-img" src="https://encrypted-tbn0.gstatic.com/images?q=tbn:ANd9GcSHo3btqZiiOgTrKCGihDfnm9V5va87up2aeg&usqp=CAU" alt="Logo">
                  <figcaption class="product-desc"><P>Bn</P></figcaption>
                  <figcaption class="product-desc2"><p>SP</p></figcaption>
                </figure>
              </a>
            </div>
  
            <div class="clients B col-6 col-md-4 col-lg-3">
              <a href="#">
                <figure class="client-container">
                  <img class="img-fluid brand-img" src="https://encrypted-tbn0.gstatic.com/images?q=tbn:ANd9GcSHo3btqZiiOgTrKCGihDfnm9V5va87up2aeg&usqp=CAU" alt="Logo">
                  <figcaption class="product-desc"><P>B</P></figcaption>
                  <figcaption class="product-desc2"><p>Wc</p></figcaption>
                </figure>
              </a>
            </div>
            </div>
          </div>
          <button onclick="togglesec1()" id="moreBtn">
            <p class="pink">Show More</p> 
            <img class="showmore" src="./images/load-more.png" alt="">
           </button>
        </div>  
      </section>
      <script src="https://cdn.jsdelivr.net/npm/@popperjs/[email protected]/dist/umd/popper.min.js" integrity="sha384-IQsoLXl5PILFhosVNubq5LC7Qb9DXgDA9i+tQ8Zj3iwWAwPtgFTxbJ8NT4GN1R8p" crossorigin="anonymous"></script>
        <script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.6.0/jquery.min.js"></script>
      <script src="https://cdn.jsdelivr.net/npm/[email protected]/dist/js/bootstrap.bundle.min.js" integrity="sha384-ka7Sk0Gln4gmtz2MlQnikT1wXgYsOg+OMhuP+IlRH9sENBO0LRn5q+8nbTov4+1p" crossorigin="anonymous"></script>
      
      <script>$(document).ready(function (){$('.list-inline-item').click(function(){const value = $(this).attr('data-filter');if(value == 'all'){$('.clients').show('1000');}else{ $('.clients').not('.'+value).hide('1000');$('.clients').filter('.'+value).show('1000');}$(this).addClass('active').siblings().removeClass('active')})})</script>

      </body>

How to do server-side date conversion and styling before sending it to jQuery datatable?

I use jQuery datatable in my project. The code for getting all data from database is:

var pm = _pmRepository.GetAllPMs().Reverse().ToList();

The repository pattern used for this purpose is:

 public IEnumerable<PM> GetAllPMs()
    {
        return context.PMs;
    }

My database has some columns with DateTime format. I want to convert date format. I have written a class that can do this:

public class DateTimeConverter
{
    PersianCalendar pc = new PersianCalendar();
public string DateConverter(string inputDate)
        {
            DateTime d = DateTime.Parse(inputDate);
            string[] convertedDateString = new string[3];
            convertedDateString[0] = pc.GetYear(d).ToString();
            convertedDateString[1] = pc.GetMonth(d).ToString();
            convertedDateString[2] = pc.GetDayOfMonth(d).ToString();
            string currentConvertedDate = string.Format("{0}/{1}/{2}", 
            convertedDateString[0], convertedDateString[1],
            convertedDateString[2]);
            return currentConvertedDate;
        }
}

How can I use my date converter before sending data to datatable?

How to push key as iterative value in js?

Hi i have a two for loop contains checking the each loop length and push into key value pair of array

for (var i=0; i<allTextLines.length; i++) {
        var data = allTextLines[i];
        if (data.length == headers.length) {

            var tarr = [];
            for (var j=0; j<headers.length; j++) 
            {
              
               ****tarr.push({headers[j]:data[j]})****
            }
            
             lines.push(tarr);

        }
        
    } 

i need to push headers[j] as key but i can’t.How to do that in JS ? I’m literally new . please bare me.THanks

React – Rerender a class component after the window pathname change

Greeting guys, I have an issue with a class component (that handle a list), the first time I mount the component works without any issue showcasing the expected values, unfortunately when I change the pathname while inside the class component it doesn’t updated.

render() {
        const service = this.state.services.find(service => service.link === window.location.pathname)
        if (service) {
            return <Service {...service} />
        }
      }

I would like to know if there is something to keep track of windows pathname in real time and maybe use the forceUpdate(); to refresh the component.

let me know if you need more information!

How to turn an object with object into array of objects [duplicate]

I want to turn an object with objects into an array of objects in javascript.

The objects looks like that

    
{
  "0": {
    "TASKCOUNT": 1,
    "ORDERID": null,
    "WORKSTATION": 1,
    "JOBSTATE": "finished"
  },
  "1": {
    "TASKCOUNT": 1,
    "ORDERID": null,
    "WORKSTATION": 1,
    "JOBSTATE": "finished"
  },
  "2": {
    "TASKCOUNT": 1,
    "ORDERID": null,
    "WORKSTATION": 1,
    "JOBSTATE": "finished"
  }
}

The Keys of the object could be just ignored, so that I have an outcome like that

[
 {
    "TASKCOUNT": 1,
    "ORDERID": null,
    "WORKSTATION": 1,
    "JOBSTATE": "finished"
  },
  {
    "TASKCOUNT": 1,
    "ORDERID": null,
    "WORKSTATION": 1,
    "JOBSTATE": "finished"
  },
  {
    "TASKCOUNT": 1,
    "ORDERID": null,
    "WORKSTATION": 1,
    "JOBSTATE": "finished"
  }
]

Thanks for any help! 

How to change title font size for excel export Datatable?

I need to add customized title for excel file exported from Datatable.
Tried this from a stackoverflow answer but it applies to whole sheet.

$("#datatable").DataTable({
          dom: "lBfrtip",
          buttons: [
            {
              extend: "excelHtml5",
              title: "Audit Trail Report",
              messageTop: `From ${this.start_date} To ${this.end_date}`,
              customize: function (xlsx) {
                var sheet = xlsx.xl["styles.xml"];
                var tagName = sheet.getElementsByTagName("sz");
                for (let i = 0; i < tagName.length; i++) {
                  tagName[i].setAttribute("val", "22");
                }
              },
            },
            {
              extend: "pdf",
              title: "Audit Trail Report",
              messageTop: `From ${this.start_date} To ${this.end_date}`,
            },
          ],
          searching: false,
        })