ContentFile() — supabase Function Reference
Architecture documentation for the ContentFile() function in content.tsx from the supabase codebase.
Entity Profile
Relationship Graph
Source Code
apps/studio/components/interfaces/Connect/content/ionicangular/supabasejs/content.tsx lines 11–143
const ContentFile = ({ projectKeys }: ContentFileProps) => {
return (
<ConnectTabs>
<ConnectTabTriggers>
<ConnectTabTrigger value="environments/environment.ts" />
<ConnectTabTrigger value="src/app/supabase.service.ts" />
<ConnectTabTrigger value="src/app/app.component.ts" />
<ConnectTabTrigger value="src/app/app.component.html" />
<ConnectTabTrigger value="src/app/app.module.ts" />
</ConnectTabTriggers>
<ConnectTabContent value="environments/environment.ts">
<SimpleCodeBlock className="ts" parentClassName="min-h-72">
{`
export const environment = {
supabaseUrl: '${projectKeys.apiUrl ?? 'your-project-url'}',
supabaseKey: '${projectKeys.publishableKey ?? '<prefer publishable key instead of anon key for mobile apps>'}',
};
`}
</SimpleCodeBlock>
</ConnectTabContent>
<ConnectTabContent value="src/app/supabase.service.ts">
<SimpleCodeBlock className="ts" parentClassName="min-h-72">
{`
import { Injectable } from '@angular/core';
import { createClient, SupabaseClient } from '@supabase/supabase-js';
import { environment } from '../environments/environment';
@Injectable({
providedIn: 'root',
})
export class SupabaseService {
private supabase: SupabaseClient;
constructor() {
this.supabase = createClient(
environment.supabaseUrl,
environment.supabaseKey
);
}
getTodos() {
return this.supabase.from('todos').select('*');
}
}
`}
</SimpleCodeBlock>
</ConnectTabContent>
<ConnectTabContent value="src/app/app.component.ts">
<SimpleCodeBlock className="ts" parentClassName="min-h-72">
{`
import { Component, OnInit } from '@angular/core';
import { SupabaseService } from './supabase.service';
@Component({
selector: 'app-root',
templateUrl: 'app.component.html',
styleUrls: ['app.component.scss'],
})
export class AppComponent implements OnInit {
todos: any[] = [];
constructor(private supabaseService: SupabaseService) {}
async ngOnInit() {
await this.loadTodos();
}
async loadTodos() {
const { data, error } = await this.supabaseService.getTodos();
if (error) {
console.error('Error fetching todos:', error);
} else {
this.todos = data;
}
}
}
`}
</SimpleCodeBlock>
</ConnectTabContent>
<ConnectTabContent value="src/app/app.component.html">
<SimpleCodeBlock className="html" parentClassName="min-h-72">
{`
<ion-header>
<ion-toolbar>
<ion-title>Todo List</ion-title>
</ion-toolbar>
</ion-header>
<ion-content>
<ion-list>
<ion-item *ngFor="let todo of todos">
<ion-label>{{ todo.title }}</ion-label>
</ion-item>
</ion-list>
</ion-content>
`}
</SimpleCodeBlock>
</ConnectTabContent>
<ConnectTabContent value="src/app/app.module.ts">
<SimpleCodeBlock className="ts" parentClassName="min-h-72">
{`
import { NgModule } from '@angular/core';
import { FormsModule } from '@angular/forms';
import { BrowserModule } from '@angular/platform-browser';
import { RouterModule } from '@angular/router';
import { IonicModule } from '@ionic/angular';
import { AppComponent } from './app.component';
import { SupabaseService } from './supabase.service';
@NgModule({
imports: [
BrowserModule,
FormsModule,
RouterModule.forRoot([]),
IonicModule.forRoot({ mode: 'ios' }),
],
declarations: [AppComponent],
providers: [SupabaseService],
bootstrap: [AppComponent],
})
export class AppModule {}
`}
</SimpleCodeBlock>
</ConnectTabContent>
</ConnectTabs>
)
}
Domain
Subdomains
Source
Analyze Your Own Codebase
Get architecture documentation, dependency graphs, and domain analysis for your codebase in minutes.
Try Supermodel Free