Uname: Linux webm012.cluster130.gra.hosting.ovh.net 5.15.167-ovh-vps-grsec-zfs-classid #1 SMP Tue Sep 17 08:14:20 UTC 2024 x86_64
Software: Apache
PHP version: 8.0.30 [ PHP INFO ] PHP os: Linux
Server Ip: 145.239.37.162
Your Ip: 216.73.216.190
User: dreampi (1009562) | Group: users (100)
Safe Mode: OFF
Disable Function:
_dyuweyrj4,_dyuweyrj4r,dl

name : colorManipulation.js
import { ref } from "vue";

function rgbaToHex (rgba) {
  if (rgba.indexOf('#') < 0) {
    let sep = rgba.indexOf(',') > -1 ? ',' : ' '
    rgba = rgba.substr(5).split(')')[0].split(sep)

    if (rgba.indexOf('/') > -1) {
      rgba.splice(3, 1)
    }

    for (let R in rgba) {
      let r = rgba[R]
      if (r.indexOf('%') > -1) {
        let p = r.substr(0, r.length - 1) / 100

        if (R < 3) {
          rgba[R] = Math.round(p * 255)
        } else {
          rgba[R] = p
        }
      }
    }

    let r = (+rgba[0]).toString(16)
    let g = (+rgba[1]).toString(16)
    let b = (+rgba[2]).toString(16)
    let a = Math.round(+rgba[3] * 255).toString(16)

    if (r.length === 1) {
      r = '0' + r
    }
    if (g.length === 1) {
      g = '0' + g
    }
    if (b.length === 1) {
      b = '0' + b
    }
    if (a.length === 1) {
      a = '0' + a
    }

    return '#' + r + g + b + a
  }

  return rgba
}

function useOppositeColor (colorData) {
  let color = rgbaToHex(colorData)
  color = color.substring(1).slice(0, 6)
  color = parseInt(color, 16)
  color = 0xFFFFFF ^ color
  color = color.toString(16)
  color = ('000000' + color).slice(-6)
  color = '#' + color
  return color
}

function useColorTransparency (color, opacity = 1) {
  if (color.indexOf('rgba') > -1) {
    color = color.substr(5).split(')')[0].split(',')
    let colorObject = {
      r: color[0].replace(' ', ''),
      g: color[1].replace(' ', ''),
      b: color[2].replace(' ', ''),
      a: opacity !== 1 ? opacity : color[3].replace(' ', '')
    }

    return `rgba(${colorObject.r}, ${colorObject.g}, ${colorObject.b}, ${colorObject.a})`
  }

  if (color.indexOf('#') > -1) {
    color = color.substr(1)
    let colorArray = []
    for (let i = 0; i < (color.length / 2); i++) {
      let a = color.substring(i * 2, (i + 1) * 2)
      a = parseInt(a, 16)
      colorArray.push(a)
    }

    return `rgba(${colorArray[0]}, ${colorArray[1]}, ${colorArray[2]}, ${opacity})`
  }

  return color
}

function useLightenDarkenColor (color, amt) {
  if (color.indexOf('#') > -1) {
    color = color.slice(1)
    color = color.length > 6 ? color.slice(0, 6) : color;

    let num = parseInt(color, 16)

    let r = (num >> 16) + amt

    if (r > 255) r = 255
    else if (r < 0) r = 0

    let g = ((num >> 8) & 0x00FF) + amt

    if (g > 255) g = 255
    else if (g < 0) g = 0

    let b = (num & 0x0000FF) + amt

    if (b > 255) b = 255
    else if (b < 0) b = 0

    return `rgba(${r}, ${g}, ${b}, 1)`
  }

  if (color.indexOf('rgba') > -1) {
    color = color
      .substr(5)
      .split(')')[0]
      .split(',')
      .map((elm, index) => {
        if (index < 3) {
          let a = parseInt(elm) + amt
          if (a > 255) return 255
          else if (a < 0) return 0
          return a
        } else {
          return Number(elm)
        }
      })

    return `rgba(${color[0]}, ${color[1]}, ${color[2]}, ${color[3]})`
  }
}

// * Colors
let amCardColors = ref([
  '#1788FB',
  '#4BBEC6',
  '#FBC22D',
  '#FA3C52',
  '#D696B8',
  '#689BCA',
  '#26CC2B',
  '#FD7E35',
  '#E38587',
  '#774DFB',
  '#31CDF3',
  '#6AB76C',
  '#FD5FA1',
  '#A697C5'
])

export { useOppositeColor, useColorTransparency, useLightenDarkenColor, amCardColors }
© 2026 GrazzMean-Shell