• Najnowsze pytania
  • Bez odpowiedzi
  • Zadaj pytanie
  • Kategorie
  • Tagi
  • Zdobyte punkty
  • Ekipa ninja
  • IRC
  • FAQ
  • Regulamin
  • Książki warte uwagi

alert toast js jak dodać możliwość koloru tła

Object Storage Arubacloud
+2 głosów
184 wizyt
pytanie zadane 25 września 2022 w JavaScript przez gatka84 Bywalec (2,150 p.)

Witajcie kombinuje jak zmieniać tło w alertach tzn tak wszystko działa tylko teraz chciałabmy to stylizować pod siebie, kod z tutoriala i tak

const DEFAULT_OPTIONS = {
  autoClose: 50000,
  position: "top-right",
  onClose: () => {},
  canClose: true,
  showProgress: true,
}

export default class Toast {
  #toastElem
  #autoCloseInterval
  #progressInterval
  #removeBinded
  #timeVisible = 0
  #autoClose
  #isPaused = false
  #unpause
  #pause
  #visibilityChange
  #shouldUnPause

  constructor(options) {
    this.#toastElem = document.createElement("div")
    this.#toastElem.classList.add("toast")   
    requestAnimationFrame(() => {
      this.#toastElem.classList.add("show")
    })
    this.#removeBinded = this.remove.bind(this)
    this.#unpause = () => (this.#isPaused = false)
    this.#pause = () => (this.#isPaused = true)
    this.#visibilityChange = () => {
      this.#shouldUnPause = document.visibilityState === "visible"
    }
    this.update({ ...DEFAULT_OPTIONS, ...options })
  }

  set autoClose(value) {
    this.#autoClose = value
    this.#timeVisible = 0
    if (value === false) return

    let lastTime
    const func = time => {
      if (this.#shouldUnPause) {
        lastTime = null
        this.#shouldUnPause = false
      }
      if (lastTime == null) {
        lastTime = time
        this.#autoCloseInterval = requestAnimationFrame(func)
        return
      }
      if (!this.#isPaused) {
        this.#timeVisible += time - lastTime
        if (this.#timeVisible >= this.#autoClose) {
          this.remove()
          return
        }
      }

      lastTime = time
      this.#autoCloseInterval = requestAnimationFrame(func)
    }

    this.#autoCloseInterval = requestAnimationFrame(func)
  }

  set position(value) {
    const currentContainer = this.#toastElem.parentElement
    const selector = `.toast-container[data-position="${value}"]`
    const container = document.querySelector(selector) || createContainer(value)
    container.append(this.#toastElem)
    if (currentContainer == null || currentContainer.hasChildNodes()) return
    currentContainer.remove()
  }


  set text(value) {
    this.#toastElem.textContent = value
  }

  set canClose(value) {
    this.#toastElem.classList.toggle("can-close", value)
    if (value) {
      this.#toastElem.addEventListener("click", this.#removeBinded)
    } else {
      this.#toastElem.removeEventListener("click", this.#removeBinded)
    }
  }

  set showProgress(value) {
    this.#toastElem.classList.toggle("progress", value)
    this.#toastElem.style.setProperty("--progress", 1)

    if (value) {
      const func = () => {
        if (!this.#isPaused) {
          this.#toastElem.style.setProperty(
            "--progress",
            1 - this.#timeVisible / this.#autoClose
          )
        }
        this.#progressInterval = requestAnimationFrame(func)
      }

      this.#progressInterval = requestAnimationFrame(func)
    }
  }

  set color(value) {
    this.#toastElem.className("color", value)
    this.#toastElem.style.setProperty("--color")
    this.#color
  }

  set pauseOnHover(value) {
    if (value) {
      this.#toastElem.addEventListener("mouseover", this.#pause)
      this.#toastElem.addEventListener("mouseleave", this.#unpause)
    } else {
      this.#toastElem.removeEventListener("mouseover", this.#pause)
      this.#toastElem.removeEventListener("mouseleave", this.#unpause)
    }
  }

  set pauseOnFocusLoss(value) {
    if (value) {
      document.addEventListener("visibilitychange", this.#visibilityChange)
    } else {
      document.removeEventListener("visibilitychange", this.#visibilityChange)
    }
  }

  update(options) {
    Object.entries(options).forEach(([key, value]) => {
      this[key] = value
    })
  }

  remove() {
    cancelAnimationFrame(this.#autoCloseInterval)
    cancelAnimationFrame(this.#progressInterval)
    const container = this.#toastElem.parentElement
    this.#toastElem.classList.remove("show")
    this.#toastElem.addEventListener("transitionend", () => {
      this.#toastElem.remove()
      if (container.hasChildNodes()) return
      container.remove()
    })
    this.onClose()
  }
}

function createContainer(position) {
  const container = document.createElement("div")
  container.classList.add("toast-container")
  container.dataset.position = position
  document.body.append(container)
  return container
}

i modyfikuje kod

const toast = new Toast({
    text: "Hello",
    position: "top-right",
    pauseOnHover: true,
    pauseOnFocusLoss: true,
  })

i teraz kombinowałam żeby wystylizować alerty do konkretnego zadania czyli danger, success itp do tej pory wzorując się na kodzie próbowałam dodać klasę i wystylizować w css jak mam tu

set position(value) {
    const currentContainer = this.#toastElem.parentElement
    const selector = `.toast-container[data-position="${value}"]`
    const container = document.querySelector(selector) || createContainer(value)
    container.append(this.#toastElem)
    if (currentContainer == null || currentContainer.hasChildNodes()) return
    currentContainer.remove()
  }

ale

const selector = `.toast-container[data-position="${value}"]`

nie bardzo potrafię wykombinować jak w podobny sposób zrobić z inną klasą gdzie po wpisaniu wartości value zostanie dodana odpowiednia klasa w css mam tak

.toast-container[data-position^="top-"] {
  top: 0;
}
.toast-container[data-position^="bottom-"] {
  bottom: 0;
}
.toast-container[data-position$="-right"] {
  right: 0;
}
.toast-container[data-position$="-left"] {
  left: 0;
}
.toast-container[data-position$="-center"] {
  left: 50%;
  transform: translateX(-50%);
}

i kombinowałam żeby dynamicznie  np color: "success" lub "danger" i je wystylizować ale jak bym nie próbowała to mi nie działa i prośba o nakierowanie jak powinno poprawnie się to zrobić bo tu jest do [data-position$=""]

2 odpowiedzi

+1 głos
odpowiedź 26 września 2022 przez VBService Ekspert (253,340 p.)
wybrane 13 października 2022 przez gatka84
 
Najlepsza

W większości "ficzerów" typu toast jest dołączony plik css, w którym np. możesz dokonać zmian.

W tym przykładzie: Toasty.js v.1.5.5 z "poziomu" options można "ingerować" w style lub wręcz zrobić Re-styling Toasts.

 

W Twoim przypadku, może spróbuj dodać klasę, klasy (css) w tym miejscu

function createContainer(position) {
  const container = document.createElement("div")
  container.classList.add("toast-container")
  container.classList.add("nazwa-klasy")
  //container.classList.add("nazwa-klasy1", "nazwa-klasy2")
  container.dataset.position = position
  document.body.append(container)
  return container
}

 

1
komentarz 13 października 2022 przez gatka84 Bywalec (2,150 p.)

Testowałam ten Toasty.js v.1.5.5 i faktycznie w miarę to prosto udało się przekształcić :)

+1 głos
odpowiedź 25 września 2022 przez Wiciorny Ekspert (270,110 p.)

a może wystylizować to za pomocą plików CSS, SCSS, a nie ingerować bezpośrednio w komponent? 

Możesz to zrobić na kilka sposóbów np. zastosowanie titleClass i messageClass , gdy używasz toastu i nadpisać wygląd w plikach css- dla odpowiednich klas.
https://getbootstrap.com/docs/4.3/components/toasts/
tu masz np. liste atrybutów

Przykład w angularze
https://github.com/scttcper/ngx-toastr#using-a-custom-toast 
oraz przykład stylowania bez angulara:
​​​​​​​https://www.cssscript.com/alert-confirm-toast-cute/

Podobne pytania

0 głosów
0 odpowiedzi 2,422 wizyt
pytanie zadane 4 lipca 2019 w JavaScript przez Ebay_05 Początkujący (400 p.)
+1 głos
3 odpowiedzi 420 wizyt
pytanie zadane 8 lipca 2020 w JavaScript przez RysiekB Nowicjusz (130 p.)
0 głosów
1 odpowiedź 966 wizyt

92,570 zapytań

141,422 odpowiedzi

319,643 komentarzy

61,958 pasjonatów

Motyw:

Akcja Pajacyk

Pajacyk od wielu lat dożywia dzieci. Pomóż klikając w zielony brzuszek na stronie. Dziękujemy! ♡

Oto polecana książka warta uwagi.
Pełną listę książek znajdziesz tutaj.

Akademia Sekuraka

Kolejna edycja największej imprezy hakerskiej w Polsce, czyli Mega Sekurak Hacking Party odbędzie się już 20 maja 2024r. Z tej okazji mamy dla Was kod: pasjamshp - jeżeli wpiszecie go w koszyku, to wówczas otrzymacie 40% zniżki na bilet w wersji standard!

Więcej informacji na temat imprezy znajdziecie tutaj. Dziękujemy ekipie Sekuraka za taką fajną zniżkę dla wszystkich Pasjonatów!

Akademia Sekuraka

Niedawno wystartował dodruk tej świetnej, rozchwytywanej książki (około 940 stron). Mamy dla Was kod: pasja (wpiszcie go w koszyku), dzięki któremu otrzymujemy 10% zniżki - dziękujemy zaprzyjaźnionej ekipie Sekuraka za taki bonus dla Pasjonatów! Książka to pierwszy tom z serii o ITsec, który łagodnie wprowadzi w świat bezpieczeństwa IT każdą osobę - warto, polecamy!

...