valtech-components 2.0.593 → 2.0.595

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,7 +1,8 @@
1
- import { Component, Input, signal } from '@angular/core';
1
+ import { Component, computed, inject, Input, signal } from '@angular/core';
2
2
  import { CommonModule } from '@angular/common';
3
3
  import { RouterLink } from '@angular/router';
4
4
  import { IonButton } from '@ionic/angular/standalone';
5
+ import { I18nService } from '../../../services/i18n';
5
6
  import * as i0 from "@angular/core";
6
7
  import * as i1 from "@angular/common";
7
8
  /**
@@ -28,7 +29,14 @@ import * as i1 from "@angular/common";
28
29
  export class Terminal404Component {
29
30
  constructor() {
30
31
  this.props = {};
32
+ this.i18n = inject(I18nService);
31
33
  this.requestedPath = signal('page-not-found');
34
+ // i18n texts - t(key, namespace)
35
+ this.directoryNotFound = computed(() => this.i18n.t('directoryNotFound', 'terminal404'));
36
+ this.searching = computed(() => this.i18n.t('searching', 'terminal404'));
37
+ this.noResults = computed(() => this.i18n.t('noResults', 'terminal404'));
38
+ this.searchTerm = computed(() => this.i18n.t('searchTerm', 'terminal404'));
39
+ this.homeButton = computed(() => this.i18n.t('homeButton', 'terminal404'));
32
40
  }
33
41
  get containerStyles() {
34
42
  const styles = {};
@@ -92,24 +100,24 @@ export class Terminal404Component {
92
100
 
93
101
  <div class="line">
94
102
  <span class="error"
95
- >bash: cd: /{{ requestedPath() }}: No existe el directorio</span
103
+ >bash: cd: /{{ requestedPath() }}: {{ directoryNotFound() }}</span
96
104
  >
97
105
  </div>
98
106
 
99
107
  <div class="line">
100
108
  <span class="prompt">user&#64;app</span>
101
109
  <span class="command">:~$ </span>
102
- <span class="command">sudo find / -name "pagina"</span>
110
+ <span class="command">sudo find / -name "{{ searchTerm() }}"</span>
103
111
  </div>
104
112
 
105
113
  <div class="line">
106
114
  <span class="info"
107
- ><span class="search-icon">🔍</span> Buscando...</span
115
+ ><span class="search-icon">🔍</span> {{ searching() }}</span
108
116
  >
109
117
  </div>
110
118
 
111
119
  <div class="line">
112
- <span class="warning">find: No se encontraron resultados.</span>
120
+ <span class="warning">find: {{ noResults() }}</span>
113
121
  </div>
114
122
 
115
123
  <div class="line">
@@ -126,7 +134,7 @@ export class Terminal404Component {
126
134
  [routerLink]="props.homeRoute || '/'"
127
135
  expand="block"
128
136
  >
129
- {{ props.homeButtonText || 'cd /home' }}
137
+ {{ props.homeButtonText || homeButton() }}
130
138
  </ion-button>
131
139
  </div>
132
140
  </div>
@@ -161,24 +169,24 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
161
169
 
162
170
  <div class="line">
163
171
  <span class="error"
164
- >bash: cd: /{{ requestedPath() }}: No existe el directorio</span
172
+ >bash: cd: /{{ requestedPath() }}: {{ directoryNotFound() }}</span
165
173
  >
166
174
  </div>
167
175
 
168
176
  <div class="line">
169
177
  <span class="prompt">user&#64;app</span>
170
178
  <span class="command">:~$ </span>
171
- <span class="command">sudo find / -name "pagina"</span>
179
+ <span class="command">sudo find / -name "{{ searchTerm() }}"</span>
172
180
  </div>
173
181
 
174
182
  <div class="line">
175
183
  <span class="info"
176
- ><span class="search-icon">🔍</span> Buscando...</span
184
+ ><span class="search-icon">🔍</span> {{ searching() }}</span
177
185
  >
178
186
  </div>
179
187
 
180
188
  <div class="line">
181
- <span class="warning">find: No se encontraron resultados.</span>
189
+ <span class="warning">find: {{ noResults() }}</span>
182
190
  </div>
183
191
 
184
192
  <div class="line">
@@ -195,7 +203,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
195
203
  [routerLink]="props.homeRoute || '/'"
196
204
  expand="block"
197
205
  >
198
- {{ props.homeButtonText || 'cd /home' }}
206
+ {{ props.homeButtonText || homeButton() }}
199
207
  </ion-button>
200
208
  </div>
201
209
  </div>
@@ -203,4 +211,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
203
211
  }], propDecorators: { props: [{
204
212
  type: Input
205
213
  }] } });
206
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"terminal-404.component.js","sourceRoot":"","sources":["../../../../../../../src/lib/components/organisms/terminal-404/terminal-404.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnInit, signal } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { RouterLink } from '@angular/router';\nimport { IonButton } from '@ionic/angular/standalone';\nimport { Terminal404Metadata } from './types';\n\n/**\n * val-terminal-404\n *\n * A fun, terminal-styled 404 page component with typing animations.\n *\n * Features:\n * - Terminal window aesthetic with colored dots\n * - Typing animation effect with sequential line reveals\n * - Blinking cursor\n * - Customizable colors to match brand\n * - Shows the attempted path\n *\n * @example\n * <val-terminal-404\n *   [props]=\"{\n *     primaryColor: '#4a1d96',\n *     homeRoute: '/',\n *     homeButtonText: 'cd /home'\n *   }\"\n * ></val-terminal-404>\n */\n@Component({\n  selector: 'val-terminal-404',\n  standalone: true,\n  imports: [CommonModule, IonButton, RouterLink],\n  styles: [\n    `\n      :host {\n        display: block;\n        width: 100%;\n        --terminal-primary: var(--ion-color-primary, #4a1d96);\n        --terminal-primary-light: var(--ion-color-primary-tint, #5b21b6);\n      }\n\n      .terminal-container {\n        min-height: 70vh;\n        display: flex;\n        flex-direction: column;\n        justify-content: center;\n        align-items: center;\n        padding: 2rem;\n        border-radius: 16px;\n      }\n\n      .terminal {\n        border-radius: 12px;\n        padding: 0;\n        max-width: 600px;\n        width: 100%;\n        box-shadow: 0 20px 60px rgba(0, 0, 0, 0.3);\n        overflow: hidden;\n      }\n\n      .terminal-header {\n        background: #161b22;\n        padding: 12px 16px;\n        display: flex;\n        align-items: center;\n        gap: 8px;\n      }\n\n      .terminal-dot {\n        width: 12px;\n        height: 12px;\n        border-radius: 50%;\n      }\n\n      .dot-red {\n        background: #ff5f56;\n      }\n      .dot-yellow {\n        background: #ffbd2e;\n      }\n      .dot-green {\n        background: #27ca40;\n      }\n\n      .terminal-title {\n        flex: 1;\n        text-align: center;\n        color: #8b949e;\n        font-size: 0.85rem;\n        font-family: monospace;\n      }\n\n      .terminal-body {\n        padding: 24px;\n        font-family: 'Fira Code', 'Monaco', 'Consolas', monospace;\n        font-size: 0.95rem;\n        line-height: 1.8;\n      }\n\n      .line {\n        margin-bottom: 8px;\n        opacity: 0;\n        animation: fadeIn 0.3s ease forwards;\n      }\n\n      .line:nth-child(1) {\n        animation-delay: 0.2s;\n      }\n      .line:nth-child(2) {\n        animation-delay: 0.8s;\n      }\n      .line:nth-child(3) {\n        animation-delay: 1.4s;\n      }\n      .line:nth-child(4) {\n        animation-delay: 2s;\n      }\n      .line:nth-child(5) {\n        animation-delay: 2.6s;\n      }\n      .line:nth-child(6) {\n        animation-delay: 3.2s;\n      }\n\n      @keyframes fadeIn {\n        to {\n          opacity: 1;\n        }\n      }\n\n      .prompt {\n        color: #7ee787;\n      }\n\n      .command {\n        color: #c9d1d9;\n      }\n\n      .error {\n        color: #f85149;\n      }\n\n      .info {\n        color: #58a6ff;\n      }\n\n      .warning {\n        color: #d29922;\n      }\n\n      .cursor {\n        display: inline-block;\n        width: 10px;\n        height: 18px;\n        background: #7ee787;\n        margin-left: 4px;\n        animation: blink 1s step-end infinite;\n        vertical-align: text-bottom;\n      }\n\n      @keyframes blink {\n        0%,\n        100% {\n          opacity: 1;\n        }\n        50% {\n          opacity: 0;\n        }\n      }\n\n      .error-code {\n        font-size: 6rem;\n        font-weight: 900;\n        text-align: center;\n        margin: 0.5rem 0 1rem;\n        font-family: monospace;\n      }\n\n      .action-container {\n        margin-top: 2rem;\n        text-align: center;\n        opacity: 0;\n        animation: fadeIn 0.5s ease forwards;\n        animation-delay: 3.8s;\n      }\n\n      .home-button {\n        --border-radius: 8px;\n        --background: var(--terminal-primary);\n        --background-hover: var(--terminal-primary-light);\n        font-family: monospace;\n      }\n\n      .error-code {\n        color: var(--terminal-primary);\n        text-shadow: 0 0 40px color-mix(in srgb, var(--terminal-primary) 30%, transparent);\n      }\n\n      .search-icon {\n        animation: searching 2s ease-in-out infinite;\n        display: inline-block;\n      }\n\n      @keyframes searching {\n        0%,\n        100% {\n          transform: translateX(0);\n        }\n        25% {\n          transform: translateX(5px);\n        }\n        75% {\n          transform: translateX(-5px);\n        }\n      }\n    `,\n  ],\n  template: `\n    <div\n      class=\"terminal-container\"\n      [ngStyle]=\"containerStyles\"\n    >\n      <div class=\"error-code\">404</div>\n\n      <div\n        class=\"terminal\"\n        [ngStyle]=\"{ background: props.terminalBackground || '#0d1117' }\"\n      >\n        <div class=\"terminal-header\">\n          <div class=\"terminal-dot dot-red\"></div>\n          <div class=\"terminal-dot dot-yellow\"></div>\n          <div class=\"terminal-dot dot-green\"></div>\n          <span class=\"terminal-title\">bash - 404</span>\n        </div>\n\n        <div class=\"terminal-body\">\n          <div class=\"line\">\n            <span class=\"prompt\">user&#64;app</span>\n            <span class=\"command\">:~$ </span>\n            <span class=\"command\">cd /{{ requestedPath() }}</span>\n          </div>\n\n          <div class=\"line\">\n            <span class=\"error\"\n              >bash: cd: /{{ requestedPath() }}: No existe el directorio</span\n            >\n          </div>\n\n          <div class=\"line\">\n            <span class=\"prompt\">user&#64;app</span>\n            <span class=\"command\">:~$ </span>\n            <span class=\"command\">sudo find / -name \"pagina\"</span>\n          </div>\n\n          <div class=\"line\">\n            <span class=\"info\"\n              ><span class=\"search-icon\">🔍</span> Buscando...</span\n            >\n          </div>\n\n          <div class=\"line\">\n            <span class=\"warning\">find: No se encontraron resultados.</span>\n          </div>\n\n          <div class=\"line\">\n            <span class=\"prompt\">user&#64;app</span>\n            <span class=\"command\">:~$ </span>\n            <span class=\"cursor\"></span>\n          </div>\n        </div>\n      </div>\n\n      <div class=\"action-container\">\n        <ion-button\n          class=\"home-button\"\n          [routerLink]=\"props.homeRoute || '/'\"\n          expand=\"block\"\n        >\n          {{ props.homeButtonText || 'cd /home' }}\n        </ion-button>\n      </div>\n    </div>\n  `,\n})\nexport class Terminal404Component implements OnInit {\n  @Input() props: Terminal404Metadata = {};\n\n  requestedPath = signal('page-not-found');\n\n  get containerStyles(): Record<string, string> {\n    const styles: Record<string, string> = {};\n\n    // Background gradient\n    const bg = this.props.backgroundColor;\n    if (bg) {\n      styles['background'] = `linear-gradient(135deg, ${bg.start} 0%, ${bg.middle} 50%, ${bg.end} 100%)`;\n    } else {\n      styles['background'] = 'linear-gradient(135deg, #ede9fe 0%, #ddd6fe 50%, #c4b5fd 100%)';\n    }\n\n    // Override primary color if provided\n    if (this.props.primaryColor) {\n      styles['--terminal-primary'] = this.props.primaryColor;\n      styles['--terminal-primary-light'] = this.lightenColor(this.props.primaryColor);\n    }\n\n    return styles;\n  }\n\n  ngOnInit(): void {\n    if (typeof window !== 'undefined') {\n      const path = window.location.pathname.slice(1) || 'unknown';\n      this.requestedPath.set(path);\n    }\n  }\n\n  /**\n   * Lighten a hex color for hover states\n   */\n  lightenColor(hex: string): string {\n    // Simple lighten by adding to RGB values\n    const num = parseInt(hex.replace('#', ''), 16);\n    const r = Math.min(255, (num >> 16) + 20);\n    const g = Math.min(255, ((num >> 8) & 0x00ff) + 20);\n    const b = Math.min(255, (num & 0x0000ff) + 20);\n    return `#${((r << 16) | (g << 8) | b).toString(16).padStart(6, '0')}`;\n  }\n}\n"]}
214
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"terminal-404.component.js","sourceRoot":"","sources":["../../../../../../../src/lib/components/organisms/terminal-404/terminal-404.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, computed, inject, Input, OnInit, signal } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { RouterLink } from '@angular/router';\nimport { IonButton } from '@ionic/angular/standalone';\nimport { Terminal404Metadata } from './types';\nimport { I18nService } from '../../../services/i18n';\n\n/**\n * val-terminal-404\n *\n * A fun, terminal-styled 404 page component with typing animations.\n *\n * Features:\n * - Terminal window aesthetic with colored dots\n * - Typing animation effect with sequential line reveals\n * - Blinking cursor\n * - Customizable colors to match brand\n * - Shows the attempted path\n *\n * @example\n * <val-terminal-404\n *   [props]=\"{\n *     primaryColor: '#4a1d96',\n *     homeRoute: '/',\n *     homeButtonText: 'cd /home'\n *   }\"\n * ></val-terminal-404>\n */\n@Component({\n  selector: 'val-terminal-404',\n  standalone: true,\n  imports: [CommonModule, IonButton, RouterLink],\n  styles: [\n    `\n      :host {\n        display: block;\n        width: 100%;\n        --terminal-primary: var(--ion-color-primary, #4a1d96);\n        --terminal-primary-light: var(--ion-color-primary-tint, #5b21b6);\n      }\n\n      .terminal-container {\n        min-height: 70vh;\n        display: flex;\n        flex-direction: column;\n        justify-content: center;\n        align-items: center;\n        padding: 2rem;\n        border-radius: 16px;\n      }\n\n      .terminal {\n        border-radius: 12px;\n        padding: 0;\n        max-width: 600px;\n        width: 100%;\n        box-shadow: 0 20px 60px rgba(0, 0, 0, 0.3);\n        overflow: hidden;\n      }\n\n      .terminal-header {\n        background: #161b22;\n        padding: 12px 16px;\n        display: flex;\n        align-items: center;\n        gap: 8px;\n      }\n\n      .terminal-dot {\n        width: 12px;\n        height: 12px;\n        border-radius: 50%;\n      }\n\n      .dot-red {\n        background: #ff5f56;\n      }\n      .dot-yellow {\n        background: #ffbd2e;\n      }\n      .dot-green {\n        background: #27ca40;\n      }\n\n      .terminal-title {\n        flex: 1;\n        text-align: center;\n        color: #8b949e;\n        font-size: 0.85rem;\n        font-family: monospace;\n      }\n\n      .terminal-body {\n        padding: 24px;\n        font-family: 'Fira Code', 'Monaco', 'Consolas', monospace;\n        font-size: 0.95rem;\n        line-height: 1.8;\n      }\n\n      .line {\n        margin-bottom: 8px;\n        opacity: 0;\n        animation: fadeIn 0.3s ease forwards;\n      }\n\n      .line:nth-child(1) {\n        animation-delay: 0.2s;\n      }\n      .line:nth-child(2) {\n        animation-delay: 0.8s;\n      }\n      .line:nth-child(3) {\n        animation-delay: 1.4s;\n      }\n      .line:nth-child(4) {\n        animation-delay: 2s;\n      }\n      .line:nth-child(5) {\n        animation-delay: 2.6s;\n      }\n      .line:nth-child(6) {\n        animation-delay: 3.2s;\n      }\n\n      @keyframes fadeIn {\n        to {\n          opacity: 1;\n        }\n      }\n\n      .prompt {\n        color: #7ee787;\n      }\n\n      .command {\n        color: #c9d1d9;\n      }\n\n      .error {\n        color: #f85149;\n      }\n\n      .info {\n        color: #58a6ff;\n      }\n\n      .warning {\n        color: #d29922;\n      }\n\n      .cursor {\n        display: inline-block;\n        width: 10px;\n        height: 18px;\n        background: #7ee787;\n        margin-left: 4px;\n        animation: blink 1s step-end infinite;\n        vertical-align: text-bottom;\n      }\n\n      @keyframes blink {\n        0%,\n        100% {\n          opacity: 1;\n        }\n        50% {\n          opacity: 0;\n        }\n      }\n\n      .error-code {\n        font-size: 6rem;\n        font-weight: 900;\n        text-align: center;\n        margin: 0.5rem 0 1rem;\n        font-family: monospace;\n      }\n\n      .action-container {\n        margin-top: 2rem;\n        text-align: center;\n        opacity: 0;\n        animation: fadeIn 0.5s ease forwards;\n        animation-delay: 3.8s;\n      }\n\n      .home-button {\n        --border-radius: 8px;\n        --background: var(--terminal-primary);\n        --background-hover: var(--terminal-primary-light);\n        font-family: monospace;\n      }\n\n      .error-code {\n        color: var(--terminal-primary);\n        text-shadow: 0 0 40px color-mix(in srgb, var(--terminal-primary) 30%, transparent);\n      }\n\n      .search-icon {\n        animation: searching 2s ease-in-out infinite;\n        display: inline-block;\n      }\n\n      @keyframes searching {\n        0%,\n        100% {\n          transform: translateX(0);\n        }\n        25% {\n          transform: translateX(5px);\n        }\n        75% {\n          transform: translateX(-5px);\n        }\n      }\n    `,\n  ],\n  template: `\n    <div\n      class=\"terminal-container\"\n      [ngStyle]=\"containerStyles\"\n    >\n      <div class=\"error-code\">404</div>\n\n      <div\n        class=\"terminal\"\n        [ngStyle]=\"{ background: props.terminalBackground || '#0d1117' }\"\n      >\n        <div class=\"terminal-header\">\n          <div class=\"terminal-dot dot-red\"></div>\n          <div class=\"terminal-dot dot-yellow\"></div>\n          <div class=\"terminal-dot dot-green\"></div>\n          <span class=\"terminal-title\">bash - 404</span>\n        </div>\n\n        <div class=\"terminal-body\">\n          <div class=\"line\">\n            <span class=\"prompt\">user&#64;app</span>\n            <span class=\"command\">:~$ </span>\n            <span class=\"command\">cd /{{ requestedPath() }}</span>\n          </div>\n\n          <div class=\"line\">\n            <span class=\"error\"\n              >bash: cd: /{{ requestedPath() }}: {{ directoryNotFound() }}</span\n            >\n          </div>\n\n          <div class=\"line\">\n            <span class=\"prompt\">user&#64;app</span>\n            <span class=\"command\">:~$ </span>\n            <span class=\"command\">sudo find / -name \"{{ searchTerm() }}\"</span>\n          </div>\n\n          <div class=\"line\">\n            <span class=\"info\"\n              ><span class=\"search-icon\">🔍</span> {{ searching() }}</span\n            >\n          </div>\n\n          <div class=\"line\">\n            <span class=\"warning\">find: {{ noResults() }}</span>\n          </div>\n\n          <div class=\"line\">\n            <span class=\"prompt\">user&#64;app</span>\n            <span class=\"command\">:~$ </span>\n            <span class=\"cursor\"></span>\n          </div>\n        </div>\n      </div>\n\n      <div class=\"action-container\">\n        <ion-button\n          class=\"home-button\"\n          [routerLink]=\"props.homeRoute || '/'\"\n          expand=\"block\"\n        >\n          {{ props.homeButtonText || homeButton() }}\n        </ion-button>\n      </div>\n    </div>\n  `,\n})\nexport class Terminal404Component implements OnInit {\n  @Input() props: Terminal404Metadata = {};\n\n  private i18n = inject(I18nService);\n\n  requestedPath = signal('page-not-found');\n\n  // i18n texts - t(key, namespace)\n  directoryNotFound = computed(() =>\n    this.i18n.t('directoryNotFound', 'terminal404')\n  );\n  searching = computed(() => this.i18n.t('searching', 'terminal404'));\n  noResults = computed(() => this.i18n.t('noResults', 'terminal404'));\n  searchTerm = computed(() => this.i18n.t('searchTerm', 'terminal404'));\n  homeButton = computed(() => this.i18n.t('homeButton', 'terminal404'));\n\n  get containerStyles(): Record<string, string> {\n    const styles: Record<string, string> = {};\n\n    // Background gradient\n    const bg = this.props.backgroundColor;\n    if (bg) {\n      styles['background'] = `linear-gradient(135deg, ${bg.start} 0%, ${bg.middle} 50%, ${bg.end} 100%)`;\n    } else {\n      styles['background'] = 'linear-gradient(135deg, #ede9fe 0%, #ddd6fe 50%, #c4b5fd 100%)';\n    }\n\n    // Override primary color if provided\n    if (this.props.primaryColor) {\n      styles['--terminal-primary'] = this.props.primaryColor;\n      styles['--terminal-primary-light'] = this.lightenColor(this.props.primaryColor);\n    }\n\n    return styles;\n  }\n\n  ngOnInit(): void {\n    if (typeof window !== 'undefined') {\n      const path = window.location.pathname.slice(1) || 'unknown';\n      this.requestedPath.set(path);\n    }\n  }\n\n  /**\n   * Lighten a hex color for hover states\n   */\n  lightenColor(hex: string): string {\n    // Simple lighten by adding to RGB values\n    const num = parseInt(hex.replace('#', ''), 16);\n    const r = Math.min(255, (num >> 16) + 20);\n    const g = Math.min(255, ((num >> 8) & 0x00ff) + 20);\n    const b = Math.min(255, (num & 0x0000ff) + 20);\n    return `#${((r << 16) | (g << 8) | b).toString(16).padStart(6, '0')}`;\n  }\n}\n"]}
@@ -31147,7 +31147,14 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
31147
31147
  class Terminal404Component {
31148
31148
  constructor() {
31149
31149
  this.props = {};
31150
+ this.i18n = inject(I18nService);
31150
31151
  this.requestedPath = signal('page-not-found');
31152
+ // i18n texts - t(key, namespace)
31153
+ this.directoryNotFound = computed(() => this.i18n.t('directoryNotFound', 'terminal404'));
31154
+ this.searching = computed(() => this.i18n.t('searching', 'terminal404'));
31155
+ this.noResults = computed(() => this.i18n.t('noResults', 'terminal404'));
31156
+ this.searchTerm = computed(() => this.i18n.t('searchTerm', 'terminal404'));
31157
+ this.homeButton = computed(() => this.i18n.t('homeButton', 'terminal404'));
31151
31158
  }
31152
31159
  get containerStyles() {
31153
31160
  const styles = {};
@@ -31211,24 +31218,24 @@ class Terminal404Component {
31211
31218
 
31212
31219
  <div class="line">
31213
31220
  <span class="error"
31214
- >bash: cd: /{{ requestedPath() }}: No existe el directorio</span
31221
+ >bash: cd: /{{ requestedPath() }}: {{ directoryNotFound() }}</span
31215
31222
  >
31216
31223
  </div>
31217
31224
 
31218
31225
  <div class="line">
31219
31226
  <span class="prompt">user&#64;app</span>
31220
31227
  <span class="command">:~$ </span>
31221
- <span class="command">sudo find / -name "pagina"</span>
31228
+ <span class="command">sudo find / -name "{{ searchTerm() }}"</span>
31222
31229
  </div>
31223
31230
 
31224
31231
  <div class="line">
31225
31232
  <span class="info"
31226
- ><span class="search-icon">🔍</span> Buscando...</span
31233
+ ><span class="search-icon">🔍</span> {{ searching() }}</span
31227
31234
  >
31228
31235
  </div>
31229
31236
 
31230
31237
  <div class="line">
31231
- <span class="warning">find: No se encontraron resultados.</span>
31238
+ <span class="warning">find: {{ noResults() }}</span>
31232
31239
  </div>
31233
31240
 
31234
31241
  <div class="line">
@@ -31245,7 +31252,7 @@ class Terminal404Component {
31245
31252
  [routerLink]="props.homeRoute || '/'"
31246
31253
  expand="block"
31247
31254
  >
31248
- {{ props.homeButtonText || 'cd /home' }}
31255
+ {{ props.homeButtonText || homeButton() }}
31249
31256
  </ion-button>
31250
31257
  </div>
31251
31258
  </div>
@@ -31280,24 +31287,24 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
31280
31287
 
31281
31288
  <div class="line">
31282
31289
  <span class="error"
31283
- >bash: cd: /{{ requestedPath() }}: No existe el directorio</span
31290
+ >bash: cd: /{{ requestedPath() }}: {{ directoryNotFound() }}</span
31284
31291
  >
31285
31292
  </div>
31286
31293
 
31287
31294
  <div class="line">
31288
31295
  <span class="prompt">user&#64;app</span>
31289
31296
  <span class="command">:~$ </span>
31290
- <span class="command">sudo find / -name "pagina"</span>
31297
+ <span class="command">sudo find / -name "{{ searchTerm() }}"</span>
31291
31298
  </div>
31292
31299
 
31293
31300
  <div class="line">
31294
31301
  <span class="info"
31295
- ><span class="search-icon">🔍</span> Buscando...</span
31302
+ ><span class="search-icon">🔍</span> {{ searching() }}</span
31296
31303
  >
31297
31304
  </div>
31298
31305
 
31299
31306
  <div class="line">
31300
- <span class="warning">find: No se encontraron resultados.</span>
31307
+ <span class="warning">find: {{ noResults() }}</span>
31301
31308
  </div>
31302
31309
 
31303
31310
  <div class="line">
@@ -31314,7 +31321,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
31314
31321
  [routerLink]="props.homeRoute || '/'"
31315
31322
  expand="block"
31316
31323
  >
31317
- {{ props.homeButtonText || 'cd /home' }}
31324
+ {{ props.homeButtonText || homeButton() }}
31318
31325
  </ion-button>
31319
31326
  </div>
31320
31327
  </div>