Passport.js – req.isAuthenticated is not a function

I’m new to node and express and node and I’m building an authentication feature with passport.js. In my routes I’m using a middleware function called “checkNotAuthenticated” to check if the user is not authenticated, but I’m getting this error: “TypeError: req.isAuthenticated is not a function”

What could the problem be here?

My routes:

const express = require('express')
const router = express.Router()
const bcrypt = require('bcrypt')
const passport = require('passport')
const flash = require('express-flash')
const session = require('express-session')
const methodOverride = require('method-override')

const User = require('../models/user.model')
const initializePassport = require('../passport-config')
initializePassport(passport)

const app = express()

app.use(flash())
app.use(session({
  secret: process.env.SESSION_SECRET,
  resave: false,
  saveUninitialized: false
}))
app.use(passport.initialize())
app.use(passport.session())
app.use(methodOverride('_method'))

/* Middleware function to check if user is authenticated */
function checkNotAuthenticated(req, res, next) {
  if (req.isAuthenticated()) {
    return res.redirect('/')
  }
  next()
}

/* ------- Routes ------- */
/* Create new user */
router.post('/register', checkNotAuthenticated, async (req, res) => {

  /* Check if the email isn't already taken */
  const emailIsTaken = await User.findOne({email: req.body.email})
  if (emailIsTaken) return res.status(500).send('Email already used')

  try {
    const hashedPassword = await bcrypt.hash(req.body.password, 10)

    const user = new User({
      name: req.body.name,
      password: hashedPassword,
      email: req.body.email,
      title: req.body.title,
      about: req.body.about
    })

    user.save()

    res.send('Success - User created')

  } catch (err) {
    res.status(500).send(err)
  }

})

/* Login user */
router.post('/login', checkNotAuthenticated, passport.authenticate('local', {
  successRedirect: '/',
  failureRedirect: '/login',
  failureFlash: true
}))

/* Logout */
router.delete('/logout', (req, res) => {
  req.logOut()
  res.redirect('/login')
})

module.exports = router

passport-config.js:

const User = require('./models/user.model')
const LocalStrategy = require('passport-local').Strategy
const bcrypt = require('bcrypt')

function initializePassport(passport) {

    const authenticateUser = async done => {

        /* Check if there's a user account created with that email */
        const userFound = await User.findOne({email: req.body.email})
        if (!userFound) return done(null, false, {message: 'Cannot find user with that email'})
        
        /* Validate password */
        try {
            const checkPassword = await bcrypt.compare(req.body.password, userFound.password)

            if (checkPassword) {
                return done(null, userFound)
            } else {
                return done(null, false, {message: 'Incorrect password'})
            }
            
        } catch (err) {
            return done(err)
            
        }
    }

    passport.use(new LocalStrategy( { usernameField: 'email' }, authenticateUser) )

    passport.serializeUser(done => { done(null, userFound.id) })
    passport.deserializeUser(done => { done(null, userFound) })
}

module.exports = initializePassport

Full error:

TypeError: req.isAuthenticated is not a function
    at checkNotAuthenticated (/home/German/Desktop/ger/code/projects/helpr/helpr-back/routes/users.route.js:27:11)
    at Layer.handle [as handle_request] (/home/German/Desktop/ger/code/projects/helpr/helpr-back/node_modules/express/lib/router/layer.js:95:5)
    at next (/home/German/Desktop/ger/code/projects/helpr/helpr-back/node_modules/express/lib/router/route.js:137:13)
    at Route.dispatch (/home/German/Desktop/ger/code/projects/helpr/helpr-back/node_modules/express/lib/router/route.js:112:3)
    at Layer.handle [as handle_request] (/home/German/Desktop/ger/code/projects/helpr/helpr-back/node_modules/express/lib/router/layer.js:95:5)
    at /home/German/Desktop/ger/code/projects/helpr/helpr-back/node_modules/express/lib/router/index.js:281:22
    at Function.process_params (/home/German/Desktop/ger/code/projects/helpr/helpr-back/node_modules/express/lib/router/index.js:335:12)
    at next (/home/German/Desktop/ger/code/projects/helpr/helpr-back/node_modules/express/lib/router/index.js:275:10)
    at Function.handle (/home/German/Desktop/ger/code/projects/helpr/helpr-back/node_modules/express/lib/router/index.js:174:3)
    at router (/home/German/Desktop/ger/code/projects/helpr/helpr-back/node_modules/express/lib/router/index.js:47:12)

my javascript loop triggeres all 12 data-attributes at once

so i have been trying to make a music playlist program that, and i have been trying to make it trigger each song independantly(just like how all music players do) but my script seems to work only when i have only one song in my html, so when i added 12 songs and ordered them with data-attribute and then tried to click the button nothing happened and then i tried to use console.log to check what happened and apparently all 12 songs got triggered at once
here is my javascript
`const songs = document.querySelectorAll(“[data-songs]”);
const icons = document.querySelector(“#icon”);

`
songs.forEach((song) => {
  icon.addEventListener("click", function () {
    console.log(song);
    //put code of icon here
    if (mySong.paused) {
      mySong.play();
      icon.src = "/images/pause.png";
    } else {
      mySong.pause();
      icon.src = "/images/play.png";
    }
  });
});
`

and here is my html


    <!DOCTYPE html>
    <html lang="en">
      <head>
        <meta charset="UTF-8" />
        <meta http-equiv="X-UA-Compatible" content="IE=edge" />
        <meta name="viewport" content="width=device-width, initial-scale=1.0" />
        <link rel="stylesheet" href="/css/styles.css" />
        <link
          rel="stylesheet"
          href="https://cdn.jsdelivr.net/npm/[email protected]/dist/css/bootstrap.min.css"
        />
        <link
          rel="stylesheet"
          href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/4.7.0/css/font-awesome.min.css"
        />
        <title>Music App</title>
      </head>
      <body>
        <div class="music-container">
          <div class="music-header">
            <i class="fa fa-angle-left"></i>
            <div class="title">
              <p>My Music</p>
            </div>
            <i class="fa fa-search"> </i>
          </div>
          <div class="music-playlist">
            <div class="music-menu text-center">
              <div class="menu">
                <ul>
                  <li><a href="#">Songs</a></li>
                  <li><a href="#">Albums</a></li>
                  <li><a href="#">Artist</a></li>
                  <li><a href="#">Generes</a></li>
                </ul>
              </div>
            </div>
            <div class="music-box">
              <div class="music-info">
                <div class="music-img">
                  <img src="images/Filosofem.jpg" alt="" />
                </div>
                <div class="music-name">
                  <h6>Single Song Title</h6>
                  <audio id="mySong" data-songs="1">
                    <source src="/music/a.mp3" type="audio/mp3" />
                  </audio>
                  <p>Single name and music director</p>
                </div>
                <img src="/images/play.png" id="icon" style="padding-right: 20px" />
              </div>
              <hr />
              <div class="music-info">
                <div class="music-img">
                  <img src="images/Filosofem.jpg" alt="" />
                </div>
                <div class="music-name">
                  <h6>Single Song Title</h6>
                  <audio id="mySong" data-songs="2">
                    <source src="/music/b.mp3" type="audio/mp3" />
                  </audio>
                  <p>Single name and music director</p>
                </div>
                <img src="/images/play.png" id="icon" style="padding-right: 20px" />
              </div>
              <hr />
              <div class="music-info">
                <div class="music-img">
                  <img src="images/Filosofem.jpg" alt="" />
                </div>
                <div class="music-name">
                  <h6>Single Song Title</h6>
                  <audio id="mySong" data-songs="3">
                    <source src="/music/c.mp3" type="audio/mp3" />
                  </audio>
                  <p>Single name and music director</p>
                </div>
                <img src="/images/play.png" id="icon" style="padding-right: 20px" />
              </div>
              <hr />
              <div class="music-info">
                <div class="music-img">
                  <img src="images/Filosofem.jpg" alt="" />
                </div>
                <div class="music-name">
                  <h6>Single Song Title</h6>
                  <audio id="mySong" data-songs="4">
                    <source src="/music/d.mp3" type="audio/mp3" />
                  </audio>
                  <p>Single name and music director</p>
                </div>
                <img src="/images/play.png" id="icon" style="padding-right: 20px" />
              </div>
              <hr />
              <div class="music-info">
                <div class="music-img">
                  <img src="images/Filosofem.jpg" alt="" />
                </div>
                <div class="music-name">
                  <h6>burzum</h6>
                  <audio id="mySong" data-songs="5">
                    <source src="/music/e.mp3" type="audio/mp3" />
                  </audio>
                  <p>Single name and music director</p>
                </div>
                <img src="/images/play.png" id="icon" style="padding-right: 20px" />
              </div>
              <hr />
              <div class="music-info">
                <div class="music-img">
                  <img src="images/Filosofem.jpg" alt="" />
                </div>
                <div class="music-name">
                  <h6>Single Song Title</h6>
                  <audio id="mySong" data-songs="6">
                    <source src="/music/f.mp3" type="audio/mp3" />
                  </audio>
                  <p>Single name and music director</p>
                </div>
                <img src="/images/play.png" id="icon" style="padding-right: 20px" />
              </div>
              <hr />
              <div class="music-info">
                <div class="music-img">
                  <img src="images/Filosofem.jpg" alt="" />
                </div>
                <div class="music-name">
                  <h6>Single Song Title</h6>
                  <audio id="mySong" data-songs="7">
                    <source src="/music/g.mp3" type="audio/mp3" />
                  </audio>
                  <p>Single name and music director</p>
                </div>
                <img src="/images/play.png" id="icon" style="padding-right: 20px" />
              </div>
              <hr />
              <div class="music-info">
                <div class="music-img">
                  <img src="images/Filosofem.jpg" alt="" />
                </div>
                <div class="music-name">
                  <h6>Single Song Title</h6>
                  <audio id="mySong" data-songs="8">
                    <source src="/music/h.mp3" type="audio/mp3" />
                  </audio>
                  <p>Single name and music director</p>
                </div>
                <img src="/images/play.png" id="icon" style="padding-right: 20px" />
              </div>
              <hr />
              <div class="music-info">
                <div class="music-img">
                  <img src="images/Filosofem.jpg" alt="" />
                </div>
                <div class="music-name">
                  <h6>Single Song Title</h6>
                  <audio id="mySong" data-songs="9">
                    <source src="/music/i.mp3" type="audio/mp3" />
                  </audio>
                  <p>Single name and music director</p>
                </div>
                <img src="/images/play.png" id="icon" style="padding-right: 20px" />
              </div>
              <hr />
              <div class="music-info">
                <div class="music-img">
                  <img src="images/Filosofem.jpg" alt="" />
                </div>
                <div class="music-name">
                  <h6>Single Song Title</h6>
                  <audio id="mySong" data-songs="10">
                    <source src="/music/j.mp3" type="audio/mp3" />
                  </audio>
                  <p>Single name and music director</p>
                </div>
                <img src="/images/play.png" id="icon" style="padding-right: 20px" />
              </div>
              <hr />
              <div class="music-info">
                <div class="music-img">
                  <img src="images/Filosofem.jpg" alt="" />
                </div>
                <div class="music-name">
                  <h6>Single Song Title</h6>
                  <audio id="mySong" data-songs="11">
                    <source src="/music/k.mp3" type="audio/mp3" />
                  </audio>
                  <p>Single name and music director</p>
                </div>
                <img src="/images/play.png" id="icon" style="padding-right: 20px" />
              </div>
              <hr />
              <div class="music-info">
                <div class="music-img">
                  <img src="images/Filosofem.jpg" alt="" />
                </div>
                <div class="music-name">
                  <h6>Single Song Title</h6>
                  <audio id="mySong" data-songs="12">
                    <source src="/music/m.mp3" type="audio/mp3" />
                  </audio>
                  <p>Single name and music director</p>
                </div>
                <img src="/images/play.png" id="icon" style="padding-right: 20px" />
              </div>
            </div>
          </div>
          <div class="music-play">
            <div class="play-image">
              <img src="images/Filosofem.jpg" alt="" />
            </div>
            <div class="play-controls">
              <div class="controls">
                <div class="song-name">
                  <h5>Dunkelheit</h5>
                  <p>Burzum</p>
                </div>
                <div class="play-icon">
                  <i class="fa fa-step-backward"> </i>
                  <i class="fa fa-play"> </i>
                  <i class="fa fa-step-forward"> </i>
                </div>
              </div>
              <div class="music-progress">
                <div class="progress">
                  <div class="progress-bar"></div>
                </div>
              </div>
            </div>
          </div>
        </div>
        <script src="/Script/jquery-3.6.0.min.js"></script>
        <script src="/Script/script.js"></script>
      </body>
    </html>
    ```

Betheme mobile hamburger menu

so I have a page on my website that use anchor links that can be accessed in menu but on mobile when I click on a category (anchor link) the menu isn’t closing automatically, I need to close manually by pressing on hamburger menu again.
This this is all my code from menu.js:

https://pastebin.com/hTL6wx2Q

This doMenu function :


            if( ( window.innerWidth >= options.mobileInit ) || ( ! options.responsive ) ){
                
                // desktop --------------------------------

                $( '> li, ul:not(.mfn-megamenu) li', menu ).hover(function() {
                    
                    $(this).stop(true,true).addClass( options.hoverClass );
                    
                    $(this).children( 'ul' ).stop(true,true).fadeIn( options.delay );
                    
                    
                }, function(){
                    
                    $(this).stop(true,true).removeClass( options.hoverClass );
                    
                    $(this).children( 'ul' ).stop(true,true).fadeOut( options.delay );  
                    
                });
                
            } else {

                // mobile ---------------------------------
                
                $( 'li', menu ).unbind('hover');
                
                $( 'li > .menu-toggle', menu ).off('click').on('click', function(){
    
                    var el = $(this).closest('li');
                    
                    if( el.hasClass( options.hoverClass ) ){
    
                        el.removeClass( options.hoverClass )
                            .children('ul').stop(true,true).fadeOut( options.delay );           
                        
                    } else {
        
                        el.addClass( options.hoverClass )
                            .children('ul').stop(true,true).fadeIn( options.delay );    
    
                    }
                    
                });
                
            }
            
        };

i18next will not load custom namespace

I have an instance of i18next running as it should if I include the translations inside the init:


i18next.use(httpAPI).init({
    lng: language,
    resources: {
      en: {
        translation: {
          "html1": "foo! ",
          "html2":"bar",
        }
      },
      de: {
        translation: {
          "html1": "de-foo",
          "html2":"de-bar",
    
        }
      }
  }
})

However, I expect to be expanding my translations, and placing them in the init would become unwieldy. So I would like to split them into multiple files. I have read about using i18next.http-backend. So when I re-write my init to include the backend my init looks like this:

i18next.use(httpAPI).init({
    lng: language,
    backend:{ loadPath: '/locales/de-DE/translate.json'}
})

the translate.json file looks like this:

{"translation": {
  "html1": "backend-de-foo",
  "html2": "backend-de-bar",
}}

My main script where I am calling the i18next is in the parent directory along with my locale folder.

It does not appear to be reading from the backend loadpath, as I am not getting any translations from it. Am I missing something from i18next or is my translate file not structured properly?

How can i divide the string into 496 rows and subdivide them according to heading in javascript

ptr[97,186,286,380,433,496]
strpar["BRACKENRIDGE: This is March the 7th, 2018. I'm R. Douglas Brackenridge, Professor Emeritus at Trinity University. With me here at Trinity is Jes Neal who is the Trinity University archivist. And we will be interviewing Betty Meadows, who is a Trinity graduate. Now, what years? You came in--? MEADOWS: I came in 1966 and left in 1970. BRACKENRIDGE: Okay, from 1966 to 1970. And you played tennis at Trinity. Is that correct? MEADOWS: I did. BRACKENRIDGE: Did you play any other sports? MEADOWS: No. BRACKENRIDGE: With that bit of introduction, let me just start back and say, how did you end up at Trinity? MEADOWS: [laugh] BRACKENRIDGE: How did you come to Trinity? And did tennis have anything to do with it when you came? MEADOWS: No. No, no. And I hope I'm going to be helpful, but my memory isn't great about all that. But anyway, I came to Trinity because I'm a Presbyterian and I've always wanted to go to a Presbyterian college. And we lived out in West Texas in a little town called Monahans, which is where I learned to play tennis. And when we moved to San Antonio, wow, I was able to just drive across town and go to college. But I stayed in the dorm; I didn't stay in my parents' home or in my home. But it's a school I always wanted to go to because I heard of its reputation. It did have a tennis team, but that's not really why I came. I came for academics. I came because it was a Presbyterian school. BRACKENRIDGE: And it would have been like maybe your (SP) minister that had any influence on you? MEADOWS: No, no. I was going to be a school teacher. My parents--my dad's a principal, my mother's a teacher, my brother's a teacher. I came to be an education major. Had no intention ever of working in a church, ever. And that call from God didn't come until 10 years later. It came in 1980, and it was a really powerful call. So I left--I went to seminary. But it was not my intention. BRACKENRIDGE: Where did you go? To Austin? MEADOWS: Austin Seminary. BRACKENRIDGE: Just an aside, did you know Bill Walker from Grand Falls? MEADOWS: No. BRACKENRIDGE: (INAUDIBLE) Monahans. Grand Falls was pretty close to Monahans. MEADOWS: It is. Yeah. BRACKENRIDGE: Yeah. But he was born and raised in Grand Falls. MEADOWS: Oh my goodness. BRACKENRIDGE: And he said there's no Grand Falls there. MEADOWS: No, there's no Grand Falls. BRACKENRIDGE: So then what did you major in, Betty? MEADOWS: Elementary education. And I took 21 years of Latin. BRACKENRIDGE: Wow. MEADOWS: Yeah, wow. BRACKENRIDGE: How old were you when you really left Monahans? MEADOWS: Sixteen. BRACKENRIDGE: Okay, so you really grew up there. MEADOWS: I did. BRACKENRIDGE: And again, we're focusing on the athletic part, but did you play tennis and that out there? MEADOWS: I did, I did. I started playing tennis in the seventh grade. And we called it junior high in those days. I started in seventh grade tennis. And the reason I started is we didn't have a girls tennis team and they were trying to get players together and the coach said, "You want to learn?" And he sent me to a tournament in three weeks. I had no idea what I was doing. I had no idea how to hit a ball. But I went to the tournament and had a riot. And we didn't win anything because nobody could hit, but at least the school was able to put in a tennis team, a doubles team. And from that point, it just kind of--it was in my blood. I loved it. And I got better and better. And so I played all the way through high school and a good bit through college. In fact, when I graduated, Doug, I actually coached tennis on the side in San Antonio for a number of years, and loved it. I taught boys and girls how to play. And then when I moved to middle school and started teaching sixth, seventh, and eighth graders, I was the tennis coach after school. And I loved it. I mean, I just loved it. It was a great way to work with kids and give them some support and teach them a skill and teach them also what is etiquette and what is tennis etiquette. And if you threw your racket or said curse words, I withdrew you from the tournament and said, "That's tough." [laugh] Anyway, but I just loved it. Tennis was a great--get you in the sun, got you exercise, got you with other people. Competitive but not too competitive. I mean, it's competitive enough. So, it really became a way of life. And that went into racquetball and then that went into running. And now I just go to the Y during the day. So it's just an active lifestyle. BRACKENRIDGE: Back then, what were your feelings about the fact that that women didn't have much opportunities to do these? That the men were in all these sports. Was that an issue when you were younger or was that not something you really thought much about? MEADOWS: Well, I didn't think much about it because in high school, we had a woman's basketball team. We had a woman's volleyball team. Now we had a woman's tennis team. So I don't think I thought much about it. It wasn't a plus or minus. It was just I wanted to play (INAUDIBLE). BRACKENRIDGE: Did you feel like there was much more interest in the men's sports and the women's were kind of considered just a (INAUDIBLE)? MEADOWS: Always. Always. Always. Because the men could run the whole floor in basketball. They (INAUDIBLE) football. BRACKENRIDGE: The basketball, was it still the stationary, where you couldn't--you didn't play full court? MEADOWS: You could only play half court. BRACKENRIDGE: Right. Well, they were still doing that in the early 1970s. They were still playing basketball that way. Right. MEADOWS: Yeah. The women were thought to be very brittle, very fragile. (INAUDIBLE). And I didn't think much about that either, really. I really didn't think much about that. I just knew that I liked to play tennis, and so I played tennis. And you could be as rough or you could play singles or you could play doubles and you could have mixed doubles. Yeah, yeah. I don't think I thought much about the fact that women didn't have the money. Because Trinity wasn't a big athletic school. BRACKENRIDGE: No, no. MEADOWS: It really wasn't. If I had been going--gone to University of Texas or Alabama or Georgia where you would have seen tons of money put into men's sports, it might have hit me differently. But sports were just kind of an add-on at Trinity. It wasn't-- BRACKENRIDGE: Right. Well, particularly--but tennis was the one big thing. MEADOWS: It was. It was. BRACKENRIDGE: Tennis--not in your days so much, but very shortly thereafter, that was the one sport that women could get scholarships in. And it always got high priority and publicity and an interest, where the other sports were in a definitely lower category. Tennis was a much bigger thing. MEADOWS: Yeah. So when I was there, I don't remember a lot of money being put into scholarships for sports. BRACKENRIDGE: No, there wasn't any. Of course, there wasn't any women's team then, either. So tell me, who helped you or how did you do it? Do you remember? MEADOWS: I am guessing that when I registered and I asked, "When does tennis start and where can I show up?"--and I showed up. I'm sure I just went down to the courts with my racket and talked to the coach. BRACKENRIDGE: You mean the coach Clarence Mayberry? It wasn't Shirley Rushing? Would she have anything to do with that then? MEADOWS: Shirley Rushing, I can't remember when she started. Was she there in 1966? BRACKENRIDGE: Oh, she was there in 1962. She was there in 1960. MEADOWS: Okay, because it was a female coach, so it had to be Shirley Rushing. BRACKENRIDGE: Yeah, that's who would have--yeah, because they didn't have any female coaches. There weren't any listed. She was the only woman in the PE department. MEADOWS: Okay. She was our coach. BRACKENRIDGE: Okay. [laugh] All right. I think that--okay. MEADOWS: She showed up, too. We showed up; she showed up. And we traveled to tournaments. We would all jump in the car. BRACKENRIDGE: I know she went to the tournament with you. MEADOWS: Yeah, she did. She did. BRACKENRIDGE: I guess what I'm asking you--was there any, quote, "coaching" going on or was it just you showed up and played? MEADOWS: No. There was no coaching. We just all got out on the courts and played. We just played our hearts out. BRACKENRIDGE: And then how did you decide who's going to play number one and number two? Would she have something to do with that or did you all--? MEADOWS: Well, we all knew who was number one. That was Emilie Burrer. We all knew that. BRACKENRIDGE: Well, but this is before Emilie Burrer. MEADOWS: Oh, before Emilie? BRACKENRIDGE: 1967, there's no Emilie Burrer there. MEADOWS: When did Emilie come? BRACKENRIDGE: 1968 and 1969. MEADOWS: Oh gosh, I forgot. I don't know who was first. BRACKENRIDGE: That's what I'm saying. You have Mary McLean, Ginger Parker (SP), Sally Goldschmeding, Betty Meadows and Elise Folden (SP) for 1967. So that's why this is so hard to figure out, because we didn't have all these formalities. We didn't have Trinitonian articles about it. And then even Shirley, she doesn't remember everything. I mean, I don't remember--you ask me about what I did in 1967 or 1968, I couldn't tell you. I'd have to go back and try to research it. [NEAL]: I wonder, were Mary McLean and Ginger Parker kind of the number one spots? Because (INAUDIBLE)-- BRACKENRIDGE: Well, I think Mary McLean was a noted player. I mean, I think she was-- [NEAL]: Yeah, she was in the Beaumont tennis tournament. And this is all in 1966. She gained, what is it, single competition, she went to the semifinals. BRACKENRIDGE: Yeah. That Mary McLean apparently was an outstanding player. MEADOWS: She was. BRACKENRIDGE: But you just played with each other, right? And you just played against each other? MEADOWS: Yeah, we weren't coached. We just played with each other. And those who wanted to play singles played singles. Those who liked doubles played doubles. BRACKENRIDGE: And what about schedule? Did you just go to tournaments? MEADOWS: No, we worked out almost every day, is what I remember. BRACKENRIDGE: No, but I mean, did you play other teams, so like in San Antonio? MEADOWS: Oh, yeah. We would go to tournaments. But we basically played with each other at Trinity. I don't remember playing any (INAUDIBLE)-- BRACKENRIDGE: You didn't play SAC [San Antonio College] or Saint Mary's [University] or Incarnate Word? MEADOWS: (INAUDIBLE) BRACKENRIDGE: See, they maybe--not even have a team then. Because there wasn't much going on in that (INAUDIBLE). MEADOWS: Yeah, I don't remember that. I don't remember ever playing another school in San Antonio. I know that we practiced almost every day. I remember walking back to the dorm with my tennis clothes on and I'd shower and I'd go to supper, or study, or whatever. But I don't remember--hmm. (INAUDIBLE) BRACKENRIDGE: Well, did you get to play on the upper courts? On the varsity courts? Or did you go off campus to practice? MEADOWS: No, we played on the varsity courts. We weren't off campus at all. We would play always on campus. BRACKENRIDGE: Okay, but by your time, there weren't tennis courts down by the Sams Center, were there? MEADOWS: No. BRACKENRIDGE: No, they were there by 1970. They were there--1969 or 1970, they built those, because the NCAA was coming for the men's tournament there. But we've read or other tennis players have said that a lot of times it was hard to get on the courts because the men used them a lot and the women just had to grab whatever time they could get to play on. But you don't remember ever having a real problem about that? MEADOWS: Yeah, I don't remember that. I really don't. My memory is [laugh] that we played--there were probably certain hours that the courts were available, I guess. I don't remember. I don't remember jostling around. But my memory is it was a little unorganized. We were just out there enjoying the sport and loving it, making friends, going to tournaments, and going to school. I mean, it wasn't a money thing. It wasn't real organized. We weren't coached. BRACKENRIDGE: And did they like pay for these uniforms? Did they pay for anything, where you're wearing these outfits? No? The white dresses and-- [PERSON]: (INAUDIBLE) MEADOWS: I don't remember them paying for any of that. BRACKENRIDGE: Because now, when you traveled, did Trinity pick up any of the costs? MEADOWS: They did. All travel. BRACKENRIDGE: That would be through the PE department, where you would be getting that money. MEADOWS: Right. The food, expenses, the gasoline, whatever. Right. BRACKENRIDGE: And they paid for your food? MEADOWS: And the hotel. Oh, sure. Whatever our expenses are. And I remember we used to take turns driving. We would all pile into these big cars and we would just all take turns driving until we got there, and then we'd play ball, and then we'd all drive back. BRACKENRIDGE: And most of those would be in Texas, right? You weren't driving out of state? MEADOWS: Right. BRACKENRIDGE: Of course Texas is a big state. You could be driving up in the Panhandle, right, if there was a meeting up there. MEADOWS: Right, right. BRACKENRIDGE: And I noticed--well, I didn't bring that picture, but one of the teams was showing that they got some fancy coats. I don't remember--I thought I--that might have been a little bit later that they had some jackets that they bought, that they made or something. But that might have been after your time. MEADOWS: Yeah, I don't have any of that. No. BRACKENRIDGE: But my assumption is that Shirley Rushing was arranging all this. MEADOWS: That's my memory. BRACKENRIDGE: They often call her the sponsor. They don't call her the coach. They call her the sponsor. So I'm assuming that that's what that role meant more. Because she was a full-time PE teacher and that; she wouldn't have a lot of time to do a lot of coaching. And I don't know that tennis was her first sport. I don't think Shirley ever--I don't know that that was her sport, anyway. MEADOWS: I don't think so. Yeah. I think she was kind to organize it and to take us to tournaments and let us play. But it was for me maybe extra-intramural, extramural, whatever. BRACKENRIDGE: Jim Potter, was he there by the time you were there as intramural, do you remember? He didn't really come until like 1967 or 1968. But you weren't really involved that much with intramurals. MEADOWS: No, no, just--no. BRACKENRIDGE: It was just more the tennis, okay. MEADOWS: Just tennis. BRACKENRIDGE: So again, just that I make sure I understand, more or less your memory is that it was at registration that you were asking about tennis and somebody told you where to go, or whatever, to meet with somebody, and that's where some of the women got together, and that Shirley was the one that kind of organized it. MEADOWS: Right. She organized it, but my memory is the kindness of Emilie Burrer. Emily Burrer would work with you on any skill, any forehand, any backhand, any serve that was giving you trouble. She was just a really wonderful teammate. And she would give her time to coach any of us because there was no coach. BRACKENRIDGE: Okay, well, see, that's something that I had no idea about. And it was her winning that kind of elevated the women's tennis. MEADOWS: Yes, she was a dynamite. She was awesome. Yeah. BRACKENRIDGE: And so when she came, it was still pretty much the same thing, right? That you didn't really have a coach. MEADOWS: No. BRACKENRIDGE: And it was Shirley who would be the person who would be doing whatever was needed to be done. Is that pretty much your memory? MEADOWS: That's my memory, right. Maybe Shirley's role was to get us registered into conferences, to send the entry fee to get us there, house us, bring us back. More of an administrator, I'm guessing, for us, yeah. (INAUDIBLE) BRACKENRIDGE: One of the things that that we have--this is a kind of a side project that--you know, they have this kind of Hall of Fame for athletes here at Trinity, and I think--we think she ought to be recognized for all that she did. See, the kind of things you're talking about, nobody has any idea that that she would be involved in any way about helping. And we've got other stories where the people are saying the same kind of thing that you're saying. Oh, that she helped us and she did this and she did that. So do you remember any other kind of contact with Shirley or you had any classes, or not particularly? MEADOWS: No. It's a long time ago! BRACKENRIDGE: I know it is. I know. If you want to chime in here now--the only thing that I would ask again was your impression of--what was the feeling amongst the other students about women's tennis? Was it a big thing or a little thing or nobody paid much attention to it? Do you have any memories of that or was that not something that was of a concern to all of you? MEADOWS: I don't have any impression that it mattered to the student body. The impression I have is that we enjoyed playing and we enjoyed being with each other. We enjoyed just the athleticism. But it wasn't a big thing for the school. That's my impression. I mean, there weren't accolades, or Emily wasn't held up for all the wins she's made. Because she was our star when she got there. Yeah. I think we played because we loved the sport. We played because it was just an exhilarating feeling to go work out and come back and study. It just was great to work out all the tension through classes, and pressure. I think that was true for all of us. It wasn't awards or it was important to the school or we were in anyone's heyday of--you know. BRACKENRIDGE: Were you aware of like what later became the AIAW? When you went to these tournaments, there were different sponsors. There were invitational tournaments where the school would invite, or this larger women's group. I don't think that was as well organized when you were playing. It was more in the 1970s that it became-- MEADOWS: Right, right. I preceded that. BRACKENRIDGE: One more question. Was there any difference that you got out of playing tennis--did that add to your experience at Trinity in your education? Were there any values you see getting out of that? What would be your mindset on that? MEADOWS: I think sports are good for all people. It's a holistic kind of thing. You learn how to win well. You learn how to lose well. You learn how to compete. You learn how to care for your opponent. You learn how to treat somebody who you just beat. You learn how to work with your classmates and your other team members who lost and didn't think they were going to. It's a whole lot of life skill that comes together in sports. And winning is not the major thing, although it's important. But I think it was the whole roundedness of being an individual. That life isn't just about good grades. It's not just about always winning. But it's about how we get along with each other in the midst of all that stuff. So the life skills were, "I'm never going to be number one, and that's okay with me. I don't have to be number one in everything. I'm a good student. I'm gonna be really good at certain things. But other things I'm gonna be the mediocre." And that's a good thing to know. And mediocre is just fine. I'm never gonna be Emilie Burrer or these other people. But I can learn from them. And to be around an Emily who was so gracious with her time and her technique showed me how to graciously be a number one in anything. Her modeling was wonderful, so that you know later in life if you're number one in anything, you share what you know. It's not all about you. So I think sports is a great teacher. It's a great teaching moment for a human being. BRACKENRIDGE: That's wonderful. That's very eloquent. So what have you done in later life, Betty? You taught. You taught in the public schools? MEADOWS: I did. I taught 10 years in public school. And then I went to seminary and had a small church out in West Texas that I just adored, and wanted to be a pastor forever. But God always has God's ways. And so then I went to Atlanta where I was on the presbytery staff. So then I began to shepherd 110 churches in evangelism as an associate exec. I did that seven years. And I thought, "Oh, this is great. I could just stay here." "No," God said. "No." So then I went to Louisville as the exec. And I was the exec, the top administrative person, for 16 years, in Louisville, Kentucky, for Mid-Kentucky Presbytery. And I thought, "Oh, this is great. I'll retire from here." God said no. So then God brought me to Charlotte where I'm a transitional--general presbyter. So I've shepherded a presbytery that was broken and there was no trust. Lack of transparency. Racial issues, theological issues. And my time here is coming to an end, and we have--by God's grace and a lot of people volunteering, we've been able to heal this presbytery. God has worked with us on that. And now the new person is coming May 1 and I retire! And it has been a wonderful, wonderful journey of--thought I was going to teach forever. No. Thought I was going to be a pastor of a church forever. No. Thought I would be a general presbytery. No. I mean, every time I said, "God, this is it," God said, "Oh, no, it isn't." But I am going to retire. BRACKENRIDGE: But you're not going to stop. MEADOWS: I'm not going to stop , no. I'm going to go back--before seminary, I was teaching school, but I was working with battered women and pregnant teens. And so all I want to do is go back to hands-on street work, just volunteering my time for the sake of somebody else. And I don't need a title, don't need an office, don't need a salary to do that. And I don't need to go to another country. There's enough need in my backyard here in Charlotte. So it's come full circle, Doug Brackenridge. Full circle. So I retire from professional ministry but never from ministry. BRACKENRIDGE: Well, I guess when they say you're honorably retired, that leaves a lot of room for activity, doesn't it? MEADOWS: Tons of room. Tons of room. Yeah. BRACKENRIDGE: So it seems like--I know that there's much more involved in a ministerial call, but it seems like what you said so eloquently about tennis are exactly what you had to deal with in becoming a Presbyterian, a woman pastor, and dealing with all these issues and working with people and having to solve problems. That some of those things you learned a bit during your college years probably carried over. MEADOWS: It did. It did. I mean, what we can learn in athletics really carries through life. And also keeps our bodies healthy so that--my mother's about to turn 100, and I may follow her and I may not. We'll see. BRACKENRIDGE: Well, I was trying to think--we did meet one time. I don't remember whether it was at a general assembly. But it seemed to me we met--there was something else going--I mean, I was in Charlotte doing some research and maybe I met you at some event there, but we did meet. I remember meeting. MEADOWS: We did. I remember that, too. It was a while back. I don't remember--but it was a while back. But that's right; I remember. And I remember your class. I remember your--you had the first religion class. And I remember this strange movement inside of me one day when you were teaching. And I thought, "What is that?" And I was being drawn into ministry. Because it took 10 more years for that seed to develop roots and sprouts. But it started in your class, Doug Brackenridge. BRACKENRIDGE: Well, sometimes you don't ever hear much from students in the past, but sometimes you find, though, that many students have never been introduced to what you'd call the academic study of religion. They've never had that. And it comes as a shock to them. I know it did to me when I was in college. But that it's liberating if it's something that you can view as positive and not negative. You learn that there's something more to learn that you don't know, and you kind of move out. And I think that's one of the things that a liberal arts school should do for somebody. Not to indoctrinate them, but to open up some doors or some windows that they can look through and say, "This is the way I'm gonna follow, but I'm aware there are other ways around." That this is not for me or this is for me. But at any rate, as always, it's a pleasure, isn't it? Every time we do this, it's like we just say, "Wow." Because we're looking at newspaper clippings and we're looking at whatever, and even though I was on the campus then, I wasn't thinking about. You know, with all the little kids and family and new professor. And wow, I was just in over my head. I had never done any teaching before. But we're just so amazed at the lives of--that why we want to kind of bring this bit of history back. Because there's a richness there that is going to be lost. Already there are people from your era that are gone. So we're wanting to be able to get first hand. Because there's no way that we could learn what you said, right, without you telling us. And maybe we find somebody else who's going to tell us, but we can't find that in any of our archives. We can't find that. So we appreciate you giving the time. And I hope you, if you do come back, get back down to San Antonio, that you'll make a point of letting me know and letting us know so we can see you. [END INTERVIEW]"]
const strpar=props.transcriptstring;
  function chunkString (str, len) {
    const size=Math.ceil(str.length/len);
    const r=Array(size);
    let offset=0;
    for (let i=0;i<size;i++){
      r[i]=str.substr(offset,len)
      offset+=len;
    }
    return r;
  }
  const resultc=chunkString(strpar,496);
  console.log(resultc);

There are total 496 rows in ptr object where some text in the first 0-97 rows some text in the 97-186 rows and so on like that what i am trying to do is to parse the strpar string into total 496 rows like that:
Introduction 0-97 rows text Technical Discussion 97-186 rows text Abstract 186-286 rows text Description 286-380 rows text Output 380-433 rows text Conclusion 433-496 rows text
kindly help me out i am stucked here for many days.

Is it possible to connect an html form with an online database website?

Is it possible to connect an html form with an online database website? I found the code below with the use of php but, my sql database is on a company website so, I cannot use localhost. Is there any other way to connect the html form with the url database? So, what I want to achieve is for customers to complete my form and then the data will be automatically updated in the database. Thank you in advance!

$con = mysqli_connect(“localhost”,”your_localhost_database_user”,”your_localhost_database_password”,”your_localhost_database_db”);

Please help figuring out BottleNeck. and events in Node

I am building a project. The part I am working on right now is supposed to do the following:

  1. log in to the platform using Id and Password (done)
  2. Take the array of data (hardcoded for now)
  3. perform an API call using each element of the array, get the result for each and put it to another array
  4. In a nutshell By passing an array of ids as an Input I should get an array of its results as output

To simplify the problem even more, I have decided to use one id and pass it 1000 times instead of array of 1000 different values.

LIMITATIONS:
I can call the API 300 times per minute or else I’d get the famous “429 problems” ->

My application does not use express. I was looking for alternatives and came across bottleNeck package Here
It does exactly what I need and is supposed to limit API calls as well as perform things as retries in case of failure or events management (see the documentation in the link above).

Here is a what I have so far:

const BottleNeck = require('bottleneck');
const logger = require('./functions/logger');
/**
 * this reservoir is allowed to execute 300 requests/ minute
 */
const limiter = new BottleNeck({
    reservoir: 300, // 300 requests per minute
    reservoirRefreshAmount: 249,
    reservoirRefreshInterval: 60 * 1000, // must be divisible by 250

    trackDoneStatus: true,

    minTime: 300//5 requests per second
});
limiter.on("debug", function (message, data) {
    // Useful to figure out what the limiter is doing in real time
    // and to help debug your application
});
limiter.on("depleted", function (empty) {
    logger.info(`BottleNeck() - reservoir is empty. Waiting... ${limiter.options}`);
    // This will be called every time the reservoir drops to 0.
    // The `empty` (boolean) argument indicates whether `limiter.empty()` is currently true.
});
limiter.on("dropped", function (dropped) {
    // This will be called when a strategy was triggered.
    // The dropped request is passed to this event listener.
});
limiter.on("empty", function () {
    // This will be called when `limiter.empty()` becomes true.
});
limiter.on("error", function (error) {
    /* handle errors here */
    logger.error(`Limiter : fetched error ${error.message}`);
});

// Listen to the "failed" event
limiter.on("failed", async (error, jobInfo) => {
    const id = jobInfo.options.id;
    console.warn(`Job ${id} failed: ${error}`);

    if (jobInfo.retryCount === 0) { // Here we only retry once
        console.log(`Retrying job ${id} in 25ms!`);
        return 25;
    }
});

limiter.on("idle", function () {
    // This will be called when `limiter.empty()` is `true` and `limiter.running()` is `0`.
});
limiter.on("queued", function (info) {
    // This event is triggered when a job transitions from one Lifecycle stage to another
});
// Listen to the "retry" event
limiter.on("retry", (error, jobInfo) => console.log(`Now retrying ${jobInfo.options.id}`));

module.exports = { bottleNeck: limiter };

(assume that logger is defined using logs4js or any other.

The main piece of code :

const { logger } = require("./functions/logger");
const { moment } = require("moment");
const { toCloudLogin, youOnlyHadOneJob } = require("./functions/toCloud");
const { bottleNeck } = require("./apiBottleNeck");



const go = async () => {
    try {

        logger.info(`hello`);
        await toCloudLogin();


        logger.info(`starting the bottleneck`);
        let counter = 0;
        for (let x = 0; x < 310; x++) {                           //calling same job through bottleneck many times
            counter+=1;
            let reservoir = await bottleNeck.currentReservoir(); // returns integer of the current 
                                                                 // reservoir api calls left
            const result = await bottleNeck.schedule(async () => youOnlyHadOneJob(reservoir));

        }
        logger.info(`finished the bottleneck` + counter)

    } catch (e) {
        console.log(e);
        logger.error(`error: ${e.message} stack :${e.stack}`);
    }
}
go();

Here are my questions:

  • If bottleNeck is supposed to filter the amount of API calls , why do I still get Maximum call stack size exceeded knowing that I launch with 300 storage (which is actually 301 with 0) and 300 recharge

  • how should I implement all these events ( for example depleted:

limiter.on("depleted", function (empty) {
    logger.info(`BottleNeck() - reservoir is empty. Waiting... ${limiter.options}`);
    // This will be called every time the reservoir drops to 0.
    // The `empty` (boolean) argument indicates whether `limiter.empty()` is currently true.
});

) In my main function so that it sends me anything when reservoir is empty. I have read on event Emitters and i assume that i should limiter.emit(depleted) somewhere but I do not understand how to properly integrate it.

JavaScript callback / async problem? Background script of Chrome Extension stops function before finishing

I am trying to create a small crawler as a chrome extension. How it works is:
Open new window or tab.
Perform a search for Google / Google News / YouTube with given keywords.
Store information of the results in a small database

I first created and tested the functions with a popup.html. There it works perfectly.You click on a button and all pages are visited and the results are stored in a database. But I want to start the program without clicking anything first. That’s why I migrated it to background.js. There it also works, but only if the Service Worker / DevTool console is open. Only then it runs completely.

I would be grateful for any helpful answer.

const keywords = [
    "Keyword1",
    "Keyword2",
    // ...
    "Keyword13"
];

chrome.runtime.onStartup.addListener(() => {
    chrome.tabs.onUpdated.addListener(loadingWindow);
    openWindow();
});

// Opens new Window or Tab with the correct URL
function openWindow() {
    chrome.tabs.onUpdated.addListener(loadingWindow);
    if (runs == 0) {
        chrome.windows.create({ url: getUrl(keywords[runs]), type: "normal" }, newWindow => {
            window_id = newWindow.id;
        });
    } else {
        chrome.tabs.update(tab_id, { url: getUrl(keywords[runs]) });
    }
}

// Wait to load the new tab
function loadingWindow(tabId, changeInfo, tab) {
    if (changeInfo.status === 'complete' && tab.status == 'complete' && tab.windowId == window_id) {
        tab_id = tabId;
        console.log(tab.windowId);
        chrome.tabs.onUpdated.removeListener(loadingWindow);
        chrome.tabs.sendMessage(tab.id, { text: source }, doStuffWithDom);
    }
};

// Get information from content script -> payload and then send to database
function doStuffWithDom(domContent) {
    let payload = {... }
    var data = new FormData();
    data.append("json", JSON.stringify(payload));
    fetch(".../store.php", { method: "POST", body: data });
    crawlDone();
}

// open new window / tab or close the open window
function crawlDone() {

    runs++;
    if (runs < keywords.length) {
        openWindow();
    } else if (runs == keywords.length) {
        chrome.windows.remove(window_id);
    }
};

If the value in the price class in HTML is equal to a string, how can it be discarded and not counted and sum the rest of the values of type Number

I have this code, but I want to add it in case if the value in the price field is equal to a string, how can this value be discarded and not counted and sum the rest of the values of type number

var theSummry = 0;
$(".price").each(function() {
  theSummry += parseInt($(this).text());
})
$(".the-total").text(theSummry);
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.6.0/jquery.min.js"></script>
<table style="width:70%;text-align: center;margin: 30px auto;">
  <tr>
    <th>Person 1</th>
    <th>Person 2</th>
    <th>Person 3</th>
  </tr>
  <tr>
    <td>Emil</td>
    <td>Tobias</td>
    <td>Linus</td>
  </tr>
  <tr>
    <td>Emil</td>
    <td>Tobias</td>
    <td class="price">10</td>
  </tr>
  <tr>
    <td>Emil</td>
    <td>Tobias</td>
    <td class="price">qwe</td>
  </tr>
  <tr>
    <td>Emil</td>
    <td>Tobias</td>
    <td class="price">10</td>
  </tr>
  <tr>
    <td>Emil</td>
    <td>Tobias</td>
    <td class="price">30</td>
  </tr>
  <tr>
    <td>Emil</td>
    <td>Tobias</td>
    <td class="price">10</td>
  </tr>
  <tr class="the-total"></tr>
</table>

How can I export images path with require() from one index.js file in react naitve?

I want to export all images from one file which index.js so that If in future I have to change the path of image then I have to only make changes in one file.

like this:

export {default as avatar} from './avatar.png';
export {default as career} from './PsychoScreenImages/career.jpeg';
export {default as application} from './redeemIcons/application.jpeg';
export {default as featured} from './redeemIcons/featured.jpeg';

But I can’t do like this require(avatar) as it requires the only a path. So, How can I export and import images from just one js file?

I have Fetched Value from Ajax to the Input but when I put in alert after that, It shows NaN, Even I can See the Value in input box [closed]

I have used code of ajax to fetch the value, It appears in input box, but when I pass value to alert it show NaN and If I inspect the Input Box in code, Value not showing.

In Html Page I can see value in input box but not in inspect element, So I am unable to use this value further as its showing NaN in alert.

VSCode’s Find all references/Go to definition does not work

I have:

  • mono repository, more projects inside
  • js/ts, react
  1. When Find all references is tried on react component (I suppose on anything) that is imported in another project inside monorepo, it starts finding references.
  2. Initializing JS/TS language features starts – from Typescript and Javascript Language Features built-in extension.
  3. It takes about 2 minutes (depends on project size)
  4. After that references outside project/folder are not found
  5. During that process I cannot use Go to definition

I have also solution and will be written in answer below to help other folks (maybe my future me :D) to not waste halfday as I did on this 😉