Files
App-Estoque-LiberiKids/SETUP-RAPIDO-SUPABASE.sql
2025-11-29 21:31:52 -03:00

179 lines
5.9 KiB
SQL

-- =============================================
-- SETUP RÁPIDO SUPABASE - LIBERI KIDS CATÁLOGO
-- Execute este script completo no SQL Editor do Supabase
-- =============================================
-- 1. EXECUTAR PRIMEIRO: Estrutura completa das tabelas
-- (Cole aqui todo o conteúdo do arquivo sql/supabase-setup.sql)
-- 2. CONFIGURAR STORAGE PARA IMAGENS
INSERT INTO storage.buckets (id, name, public, file_size_limit, allowed_mime_types)
VALUES (
'produtos',
'produtos',
true,
5242880, -- 5MB
ARRAY['image/jpeg', 'image/png', 'image/webp', 'image/gif']
) ON CONFLICT (id) DO NOTHING;
-- Políticas de acesso ao storage
CREATE POLICY "Permitir upload de imagens de produtos" ON storage.objects
FOR INSERT WITH CHECK (
bucket_id = 'produtos' AND
auth.role() = 'authenticated'
);
CREATE POLICY "Permitir leitura pública de imagens de produtos" ON storage.objects
FOR SELECT USING (bucket_id = 'produtos');
CREATE POLICY "Permitir atualização de imagens de produtos" ON storage.objects
FOR UPDATE WITH CHECK (
bucket_id = 'produtos' AND
auth.role() = 'authenticated'
);
CREATE POLICY "Permitir exclusão de imagens de produtos" ON storage.objects
FOR DELETE USING (
bucket_id = 'produtos' AND
auth.role() = 'authenticated'
);
-- 3. CRIAR TABELA DE USUÁRIOS ADMIN
CREATE TABLE IF NOT EXISTS usuarios_admin (
id UUID DEFAULT uuid_generate_v4() PRIMARY KEY,
email VARCHAR(255) NOT NULL UNIQUE,
senha_hash VARCHAR(255) NOT NULL,
nome VARCHAR(255) NOT NULL,
ativo BOOLEAN DEFAULT true,
created_at TIMESTAMP WITH TIME ZONE DEFAULT NOW()
);
-- 4. INSERIR USUÁRIO ADMIN DA MAIARA
INSERT INTO usuarios_admin (email, senha_hash, nome, ativo)
VALUES (
'maiara.seco@gmail.com',
'e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855', -- Hash de '123456'
'Maiara Seco',
true
) ON CONFLICT (email) DO NOTHING;
-- 5. INSERIR DADOS DE TESTE
-- Fornecedor de exemplo
INSERT INTO fornecedores (nome, email, telefone, ativo)
VALUES (
'Liberi Kids Matriz',
'contato@liberikids.com.br',
'(43) 99999-9999',
true
) ON CONFLICT DO NOTHING;
-- Produtos de exemplo
INSERT INTO produtos (
id_produto, marca, nome, descricao, estacao, genero,
fornecedor_id, valor_compra, valor_revenda, ativo
)
VALUES
(
'LK001',
'Liberi Kids',
'Camiseta Infantil Básica',
'Camiseta 100% algodão, confortável e durável para o dia a dia',
'Verão',
'Unissex',
(SELECT id FROM fornecedores WHERE nome = 'Liberi Kids Matriz' LIMIT 1),
15.90,
29.90,
true
),
(
'LK002',
'Liberi Kids',
'Vestido Floral Menina',
'Vestido lindo com estampa floral, perfeito para ocasiões especiais',
'Primavera',
'Feminino',
(SELECT id FROM fornecedores WHERE nome = 'Liberi Kids Matriz' LIMIT 1),
25.90,
49.90,
true
),
(
'LK003',
'Liberi Kids',
'Bermuda Jeans Menino',
'Bermuda jeans resistente e confortável para brincadeiras',
'Verão',
'Masculino',
(SELECT id FROM fornecedores WHERE nome = 'Liberi Kids Matriz' LIMIT 1),
20.90,
39.90,
true
)
ON CONFLICT (id_produto) DO NOTHING;
-- Variações dos produtos
INSERT INTO produto_variacoes (produto_id, tamanho, cor, quantidade)
VALUES
-- Camiseta Básica
((SELECT id FROM produtos WHERE id_produto = 'LK001'), '2', 'Azul', 5),
((SELECT id FROM produtos WHERE id_produto = 'LK001'), '2', 'Rosa', 3),
((SELECT id FROM produtos WHERE id_produto = 'LK001'), '4', 'Azul', 7),
((SELECT id FROM produtos WHERE id_produto = 'LK001'), '4', 'Rosa', 4),
((SELECT id FROM produtos WHERE id_produto = 'LK001'), '6', 'Branco', 6),
-- Vestido Floral
((SELECT id FROM produtos WHERE id_produto = 'LK002'), '2', 'Rosa', 3),
((SELECT id FROM produtos WHERE id_produto = 'LK002'), '4', 'Rosa', 5),
((SELECT id FROM produtos WHERE id_produto = 'LK002'), '6', 'Lilás', 4),
((SELECT id FROM produtos WHERE id_produto = 'LK002'), '8', 'Rosa', 2),
-- Bermuda Jeans
((SELECT id FROM produtos WHERE id_produto = 'LK003'), '2', 'Azul', 4),
((SELECT id FROM produtos WHERE id_produto = 'LK003'), '4', 'Azul', 6),
((SELECT id FROM produtos WHERE id_produto = 'LK003'), '6', 'Azul', 3),
((SELECT id FROM produtos WHERE id_produto = 'LK003'), '8', 'Preto', 5)
ON CONFLICT (produto_id, tamanho, cor) DO NOTHING;
-- Cliente de exemplo
INSERT INTO clientes (nome_completo, email, whatsapp, endereco, ativo)
VALUES (
'Cliente Teste',
'cliente@teste.com',
'43999999999',
'Rua Teste, 123 - Centro - Londrina/PR',
true
) ON CONFLICT (whatsapp) DO NOTHING;
-- =============================================
-- VERIFICAÇÕES FINAIS
-- =============================================
-- Verificar se tudo foi criado corretamente
SELECT 'Produtos criados:' as status, COUNT(*) as total FROM produtos WHERE ativo = true;
SELECT 'Variações criadas:' as status, COUNT(*) as total FROM produto_variacoes;
SELECT 'Fornecedores criados:' as status, COUNT(*) as total FROM fornecedores WHERE ativo = true;
SELECT 'Usuários admin criados:' as status, COUNT(*) as total FROM usuarios_admin WHERE ativo = true;
SELECT 'Clientes criados:' as status, COUNT(*) as total FROM clientes WHERE ativo = true;
-- Verificar buckets de storage
SELECT 'Buckets criados:' as status, COUNT(*) as total FROM storage.buckets WHERE name = 'produtos';
-- =============================================
-- INSTRUÇÕES FINAIS
-- =============================================
/*
🎉 CONFIGURAÇÃO CONCLUÍDA!
Próximos passos:
1. ✅ Execute este script completo no SQL Editor
2. ✅ Verifique se não há erros
3. ✅ Abra site/index.html no navegador
4. ✅ Teste o carregamento de produtos
5. ✅ Acesse o admin: clique no logo
6. ✅ Login: maiara.seco@gmail.com / 123456
O catálogo agora está funcionando com dados reais!
*/