Initial commit

James Peret vor 10 Jahren
Commit
0bfe523505

+ 3 - 0
.bowerrc

@@ -0,0 +1,3 @@
1
+{
2
+  "directory": "bower_components"
3
+}

+ 21 - 0
.editorconfig

@@ -0,0 +1,21 @@
1
+# EditorConfig helps developers define and maintain consistent
2
+# coding styles between different editors and IDEs
3
+# editorconfig.org
4
+
5
+root = true
6
+
7
+
8
+[*]
9
+
10
+# Change these settings to your own preference
11
+indent_style = space
12
+indent_size = 2
13
+
14
+# We recommend you to keep these unchanged
15
+end_of_line = lf
16
+charset = utf-8
17
+trim_trailing_whitespace = true
18
+insert_final_newline = true
19
+
20
+[*.md]
21
+trim_trailing_whitespace = false

+ 1 - 0
.gitattributes

@@ -0,0 +1 @@
1
+* text=auto

+ 5 - 0
.gitignore

@@ -0,0 +1,5 @@
1
+node_modules
2
+dist
3
+.tmp
4
+.sass-cache
5
+bower_components

+ 23 - 0
.jshintrc

@@ -0,0 +1,23 @@
1
+{
2
+  "node": true,
3
+  "browser": true,
4
+  "esnext": true,
5
+  "bitwise": true,
6
+  "camelcase": true,
7
+  "curly": true,
8
+  "eqeqeq": true,
9
+  "immed": true,
10
+  "indent": 2,
11
+  "latedef": true,
12
+  "newcap": true,
13
+  "noarg": true,
14
+  "quotmark": "single",
15
+  "undef": true,
16
+  "unused": true,
17
+  "strict": true,
18
+  "trailing": true,
19
+  "smarttabs": true,
20
+  "globals": {
21
+    "angular": false
22
+  }
23
+}

+ 9 - 0
.travis.yml

@@ -0,0 +1,9 @@
1
+sudo: false
2
+language: node_js
3
+node_js:
4
+  - 'iojs'
5
+  - '0.12'
6
+  - '0.10'
7
+before_script:
8
+  - 'npm install -g bower grunt-cli'
9
+  - 'bower install'

+ 1 - 0
.yo-rc.json

@@ -0,0 +1 @@
1
+{}

+ 444 - 0
Gruntfile.js

@@ -0,0 +1,444 @@
1
+// Generated on 2015-05-16 using generator-angular 0.11.1
2
+'use strict';
3
+
4
+// # Globbing
5
+// for performance reasons we're only matching one level down:
6
+// 'test/spec/{,*/}*.js'
7
+// use this if you want to recursively match all subfolders:
8
+// 'test/spec/**/*.js'
9
+
10
+module.exports = function (grunt) {
11
+
12
+  // Load grunt tasks automatically
13
+  require('load-grunt-tasks')(grunt);
14
+
15
+  // Time how long tasks take. Can help when optimizing build times
16
+  require('time-grunt')(grunt);
17
+
18
+  // Configurable paths for the application
19
+  var appConfig = {
20
+    app: require('./bower.json').appPath || 'app',
21
+    dist: 'dist'
22
+  };
23
+
24
+  // Define the configuration for all the tasks
25
+  grunt.initConfig({
26
+
27
+    // Project settings
28
+    yeoman: appConfig,
29
+
30
+    // Watches files for changes and runs tasks based on the changed files
31
+    watch: {
32
+      bower: {
33
+        files: ['bower.json'],
34
+        tasks: ['wiredep']
35
+      },
36
+      js: {
37
+        files: ['<%= yeoman.app %>/scripts/{,*/}*.js'],
38
+        tasks: ['newer:jshint:all'],
39
+        options: {
40
+          livereload: '<%= connect.options.livereload %>'
41
+        }
42
+      },
43
+      jsTest: {
44
+        files: ['test/spec/{,*/}*.js'],
45
+        tasks: ['newer:jshint:test', 'karma']
46
+      },
47
+      styles: {
48
+        files: ['<%= yeoman.app %>/styles/{,*/}*.css'],
49
+        tasks: ['newer:copy:styles', 'autoprefixer']
50
+      },
51
+      gruntfile: {
52
+        files: ['Gruntfile.js']
53
+      },
54
+      livereload: {
55
+        options: {
56
+          livereload: '<%= connect.options.livereload %>'
57
+        },
58
+        files: [
59
+          '<%= yeoman.app %>/{,*/}*.html',
60
+          '.tmp/styles/{,*/}*.css',
61
+          '<%= yeoman.app %>/images/{,*/}*.{png,jpg,jpeg,gif,webp,svg}'
62
+        ]
63
+      }
64
+    },
65
+
66
+    // The actual grunt server settings
67
+    connect: {
68
+      options: {
69
+        port: 9000,
70
+        // Change this to '0.0.0.0' to access the server from outside.
71
+        hostname: 'localhost',
72
+        livereload: 35729
73
+      },
74
+      livereload: {
75
+        options: {
76
+          open: true,
77
+          middleware: function (connect) {
78
+            return [
79
+              connect.static('.tmp'),
80
+              connect().use(
81
+                '/bower_components',
82
+                connect.static('./bower_components')
83
+              ),
84
+              connect().use(
85
+                '/app/styles',
86
+                connect.static('./app/styles')
87
+              ),
88
+              connect.static(appConfig.app)
89
+            ];
90
+          }
91
+        }
92
+      },
93
+      test: {
94
+        options: {
95
+          port: 9001,
96
+          middleware: function (connect) {
97
+            return [
98
+              connect.static('.tmp'),
99
+              connect.static('test'),
100
+              connect().use(
101
+                '/bower_components',
102
+                connect.static('./bower_components')
103
+              ),
104
+              connect.static(appConfig.app)
105
+            ];
106
+          }
107
+        }
108
+      },
109
+      dist: {
110
+        options: {
111
+          open: true,
112
+          base: '<%= yeoman.dist %>'
113
+        }
114
+      }
115
+    },
116
+
117
+    // Make sure code styles are up to par and there are no obvious mistakes
118
+    jshint: {
119
+      options: {
120
+        jshintrc: '.jshintrc',
121
+        reporter: require('jshint-stylish')
122
+      },
123
+      all: {
124
+        src: [
125
+          'Gruntfile.js',
126
+          '<%= yeoman.app %>/scripts/{,*/}*.js'
127
+        ]
128
+      },
129
+      test: {
130
+        options: {
131
+          jshintrc: 'test/.jshintrc'
132
+        },
133
+        src: ['test/spec/{,*/}*.js']
134
+      }
135
+    },
136
+
137
+    // Empties folders to start fresh
138
+    clean: {
139
+      dist: {
140
+        files: [{
141
+          dot: true,
142
+          src: [
143
+            '.tmp',
144
+            '<%= yeoman.dist %>/{,*/}*',
145
+            '!<%= yeoman.dist %>/.git{,*/}*'
146
+          ]
147
+        }]
148
+      },
149
+      server: '.tmp'
150
+    },
151
+
152
+    // Add vendor prefixed styles
153
+    autoprefixer: {
154
+      options: {
155
+        browsers: ['last 1 version']
156
+      },
157
+      server: {
158
+        options: {
159
+          map: true,
160
+        },
161
+        files: [{
162
+          expand: true,
163
+          cwd: '.tmp/styles/',
164
+          src: '{,*/}*.css',
165
+          dest: '.tmp/styles/'
166
+        }]
167
+      },
168
+      dist: {
169
+        files: [{
170
+          expand: true,
171
+          cwd: '.tmp/styles/',
172
+          src: '{,*/}*.css',
173
+          dest: '.tmp/styles/'
174
+        }]
175
+      }
176
+    },
177
+
178
+    // Automatically inject Bower components into the app
179
+    wiredep: {
180
+      app: {
181
+        src: ['<%= yeoman.app %>/index.html'],
182
+        ignorePath:  /\.\.\//
183
+      },
184
+      test: {
185
+        devDependencies: true,
186
+        src: '<%= karma.unit.configFile %>',
187
+        ignorePath:  /\.\.\//,
188
+        fileTypes:{
189
+          js: {
190
+            block: /(([\s\t]*)\/{2}\s*?bower:\s*?(\S*))(\n|\r|.)*?(\/{2}\s*endbower)/gi,
191
+              detect: {
192
+                js: /'(.*\.js)'/gi
193
+              },
194
+              replace: {
195
+                js: '\'{{filePath}}\','
196
+              }
197
+            }
198
+          }
199
+      }
200
+    },
201
+
202
+    // Renames files for browser caching purposes
203
+    filerev: {
204
+      dist: {
205
+        src: [
206
+          '<%= yeoman.dist %>/scripts/{,*/}*.js',
207
+          '<%= yeoman.dist %>/styles/{,*/}*.css',
208
+          '<%= yeoman.dist %>/images/{,*/}*.{png,jpg,jpeg,gif,webp,svg}',
209
+          '<%= yeoman.dist %>/styles/fonts/*'
210
+        ]
211
+      }
212
+    },
213
+
214
+    // Reads HTML for usemin blocks to enable smart builds that automatically
215
+    // concat, minify and revision files. Creates configurations in memory so
216
+    // additional tasks can operate on them
217
+    useminPrepare: {
218
+      html: '<%= yeoman.app %>/index.html',
219
+      options: {
220
+        dest: '<%= yeoman.dist %>',
221
+        flow: {
222
+          html: {
223
+            steps: {
224
+              js: ['concat', 'uglifyjs'],
225
+              css: ['cssmin']
226
+            },
227
+            post: {}
228
+          }
229
+        }
230
+      }
231
+    },
232
+
233
+    // Performs rewrites based on filerev and the useminPrepare configuration
234
+    usemin: {
235
+      html: ['<%= yeoman.dist %>/{,*/}*.html'],
236
+      css: ['<%= yeoman.dist %>/styles/{,*/}*.css'],
237
+      options: {
238
+        assetsDirs: [
239
+          '<%= yeoman.dist %>',
240
+          '<%= yeoman.dist %>/images',
241
+          '<%= yeoman.dist %>/styles'
242
+        ]
243
+      }
244
+    },
245
+
246
+    // The following *-min tasks will produce minified files in the dist folder
247
+    // By default, your `index.html`'s <!-- Usemin block --> will take care of
248
+    // minification. These next options are pre-configured if you do not wish
249
+    // to use the Usemin blocks.
250
+    // cssmin: {
251
+    //   dist: {
252
+    //     files: {
253
+    //       '<%= yeoman.dist %>/styles/main.css': [
254
+    //         '.tmp/styles/{,*/}*.css'
255
+    //       ]
256
+    //     }
257
+    //   }
258
+    // },
259
+    // uglify: {
260
+    //   dist: {
261
+    //     files: {
262
+    //       '<%= yeoman.dist %>/scripts/scripts.js': [
263
+    //         '<%= yeoman.dist %>/scripts/scripts.js'
264
+    //       ]
265
+    //     }
266
+    //   }
267
+    // },
268
+    // concat: {
269
+    //   dist: {}
270
+    // },
271
+
272
+    imagemin: {
273
+      dist: {
274
+        files: [{
275
+          expand: true,
276
+          cwd: '<%= yeoman.app %>/images',
277
+          src: '{,*/}*.{png,jpg,jpeg,gif}',
278
+          dest: '<%= yeoman.dist %>/images'
279
+        }]
280
+      }
281
+    },
282
+
283
+    svgmin: {
284
+      dist: {
285
+        files: [{
286
+          expand: true,
287
+          cwd: '<%= yeoman.app %>/images',
288
+          src: '{,*/}*.svg',
289
+          dest: '<%= yeoman.dist %>/images'
290
+        }]
291
+      }
292
+    },
293
+
294
+    htmlmin: {
295
+      dist: {
296
+        options: {
297
+          collapseWhitespace: true,
298
+          conservativeCollapse: true,
299
+          collapseBooleanAttributes: true,
300
+          removeCommentsFromCDATA: true,
301
+          removeOptionalTags: true
302
+        },
303
+        files: [{
304
+          expand: true,
305
+          cwd: '<%= yeoman.dist %>',
306
+          src: ['*.html', 'views/{,*/}*.html'],
307
+          dest: '<%= yeoman.dist %>'
308
+        }]
309
+      }
310
+    },
311
+
312
+    // ng-annotate tries to make the code safe for minification automatically
313
+    // by using the Angular long form for dependency injection.
314
+    ngAnnotate: {
315
+      dist: {
316
+        files: [{
317
+          expand: true,
318
+          cwd: '.tmp/concat/scripts',
319
+          src: '*.js',
320
+          dest: '.tmp/concat/scripts'
321
+        }]
322
+      }
323
+    },
324
+
325
+    // Replace Google CDN references
326
+    cdnify: {
327
+      dist: {
328
+        html: ['<%= yeoman.dist %>/*.html']
329
+      }
330
+    },
331
+
332
+    // Copies remaining files to places other tasks can use
333
+    copy: {
334
+      dist: {
335
+        files: [{
336
+          expand: true,
337
+          dot: true,
338
+          cwd: '<%= yeoman.app %>',
339
+          dest: '<%= yeoman.dist %>',
340
+          src: [
341
+            '*.{ico,png,txt}',
342
+            '.htaccess',
343
+            '*.html',
344
+            'views/{,*/}*.html',
345
+            'images/{,*/}*.{webp}',
346
+            'styles/fonts/{,*/}*.*'
347
+          ]
348
+        }, {
349
+          expand: true,
350
+          cwd: '.tmp/images',
351
+          dest: '<%= yeoman.dist %>/images',
352
+          src: ['generated/*']
353
+        }, {
354
+          expand: true,
355
+          cwd: 'bower_components/bootstrap/dist',
356
+          src: 'fonts/*',
357
+          dest: '<%= yeoman.dist %>'
358
+        }]
359
+      },
360
+      styles: {
361
+        expand: true,
362
+        cwd: '<%= yeoman.app %>/styles',
363
+        dest: '.tmp/styles/',
364
+        src: '{,*/}*.css'
365
+      }
366
+    },
367
+
368
+    // Run some tasks in parallel to speed up the build process
369
+    concurrent: {
370
+      server: [
371
+        'copy:styles'
372
+      ],
373
+      test: [
374
+        'copy:styles'
375
+      ],
376
+      dist: [
377
+        'copy:styles',
378
+        'imagemin',
379
+        'svgmin'
380
+      ]
381
+    },
382
+
383
+    // Test settings
384
+    karma: {
385
+      unit: {
386
+        configFile: 'test/karma.conf.js',
387
+        singleRun: true
388
+      }
389
+    }
390
+  });
391
+
392
+
393
+  grunt.registerTask('serve', 'Compile then start a connect web server', function (target) {
394
+    if (target === 'dist') {
395
+      return grunt.task.run(['build', 'connect:dist:keepalive']);
396
+    }
397
+
398
+    grunt.task.run([
399
+      'clean:server',
400
+      'wiredep',
401
+      'concurrent:server',
402
+      'autoprefixer:server',
403
+      'connect:livereload',
404
+      'watch'
405
+    ]);
406
+  });
407
+
408
+  grunt.registerTask('server', 'DEPRECATED TASK. Use the "serve" task instead', function (target) {
409
+    grunt.log.warn('The `server` task has been deprecated. Use `grunt serve` to start a server.');
410
+    grunt.task.run(['serve:' + target]);
411
+  });
412
+
413
+  grunt.registerTask('test', [
414
+    'clean:server',
415
+    'wiredep',
416
+    'concurrent:test',
417
+    'autoprefixer',
418
+    'connect:test',
419
+    'karma'
420
+  ]);
421
+
422
+  grunt.registerTask('build', [
423
+    'clean:dist',
424
+    'wiredep',
425
+    'useminPrepare',
426
+    'concurrent:dist',
427
+    'autoprefixer',
428
+    'concat',
429
+    'ngAnnotate',
430
+    'copy:dist',
431
+    'cdnify',
432
+    'cssmin',
433
+    'uglify',
434
+    'filerev',
435
+    'usemin',
436
+    'htmlmin'
437
+  ]);
438
+
439
+  grunt.registerTask('default', [
440
+    'newer:jshint',
441
+    'test',
442
+    'build'
443
+  ]);
444
+};

+ 12 - 0
README.md

@@ -0,0 +1,12 @@
1
+# domain-manager
2
+
3
+This project is generated with [yo angular generator](https://github.com/yeoman/generator-angular)
4
+version 0.11.1.
5
+
6
+## Build & development
7
+
8
+Run `grunt` for building and `grunt serve` for preview.
9
+
10
+## Testing
11
+
12
+Running `grunt test` will run the unit tests with karma.

+ 1 - 0
app/.buildignore

@@ -0,0 +1 @@
1
+*.coffee

+ 543 - 0
app/.htaccess

@@ -0,0 +1,543 @@
1
+# Apache Configuration File
2
+
3
+# (!) Using `.htaccess` files slows down Apache, therefore, if you have access
4
+# to the main server config file (usually called `httpd.conf`), you should add
5
+# this logic there: http://httpd.apache.org/docs/current/howto/htaccess.html.
6
+
7
+# ##############################################################################
8
+# # CROSS-ORIGIN RESOURCE SHARING (CORS)                                       #
9
+# ##############################################################################
10
+
11
+# ------------------------------------------------------------------------------
12
+# | Cross-domain AJAX requests                                                 |
13
+# ------------------------------------------------------------------------------
14
+
15
+# Enable cross-origin AJAX requests.
16
+# http://code.google.com/p/html5security/wiki/CrossOriginRequestSecurity
17
+# http://enable-cors.org/
18
+
19
+# <IfModule mod_headers.c>
20
+#    Header set Access-Control-Allow-Origin "*"
21
+# </IfModule>
22
+
23
+# ------------------------------------------------------------------------------
24
+# | CORS-enabled images                                                        |
25
+# ------------------------------------------------------------------------------
26
+
27
+# Send the CORS header for images when browsers request it.
28
+# https://developer.mozilla.org/en/CORS_Enabled_Image
29
+# http://blog.chromium.org/2011/07/using-cross-domain-images-in-webgl-and.html
30
+# http://hacks.mozilla.org/2011/11/using-cors-to-load-webgl-textures-from-cross-domain-images/
31
+
32
+<IfModule mod_setenvif.c>
33
+    <IfModule mod_headers.c>
34
+        <FilesMatch "\.(gif|ico|jpe?g|png|svg|svgz|webp)$">
35
+            SetEnvIf Origin ":" IS_CORS
36
+            Header set Access-Control-Allow-Origin "*" env=IS_CORS
37
+        </FilesMatch>
38
+    </IfModule>
39
+</IfModule>
40
+
41
+# ------------------------------------------------------------------------------
42
+# | Web fonts access                                                           |
43
+# ------------------------------------------------------------------------------
44
+
45
+# Allow access from all domains for web fonts
46
+
47
+<IfModule mod_headers.c>
48
+    <FilesMatch "\.(eot|font.css|otf|ttc|ttf|woff)$">
49
+        Header set Access-Control-Allow-Origin "*"
50
+    </FilesMatch>
51
+</IfModule>
52
+
53
+
54
+# ##############################################################################
55
+# # ERRORS                                                                     #
56
+# ##############################################################################
57
+
58
+# ------------------------------------------------------------------------------
59
+# | 404 error prevention for non-existing redirected folders                   |
60
+# ------------------------------------------------------------------------------
61
+
62
+# Prevent Apache from returning a 404 error for a rewrite if a directory
63
+# with the same name does not exist.
64
+# http://httpd.apache.org/docs/current/content-negotiation.html#multiviews
65
+# http://www.webmasterworld.com/apache/3808792.htm
66
+
67
+Options -MultiViews
68
+
69
+# ------------------------------------------------------------------------------
70
+# | Custom error messages / pages                                              |
71
+# ------------------------------------------------------------------------------
72
+
73
+# You can customize what Apache returns to the client in case of an error (see
74
+# http://httpd.apache.org/docs/current/mod/core.html#errordocument), e.g.:
75
+
76
+ErrorDocument 404 /404.html
77
+
78
+
79
+# ##############################################################################
80
+# # INTERNET EXPLORER                                                          #
81
+# ##############################################################################
82
+
83
+# ------------------------------------------------------------------------------
84
+# | Better website experience                                                  |
85
+# ------------------------------------------------------------------------------
86
+
87
+# Force IE to render pages in the highest available mode in the various
88
+# cases when it may not: http://hsivonen.iki.fi/doctype/ie-mode.pdf.
89
+
90
+<IfModule mod_headers.c>
91
+    Header set X-UA-Compatible "IE=edge"
92
+    # `mod_headers` can't match based on the content-type, however, we only
93
+    # want to send this header for HTML pages and not for the other resources
94
+    <FilesMatch "\.(appcache|crx|css|eot|gif|htc|ico|jpe?g|js|m4a|m4v|manifest|mp4|oex|oga|ogg|ogv|otf|pdf|png|safariextz|svg|svgz|ttf|vcf|webapp|webm|webp|woff|xml|xpi)$">
95
+        Header unset X-UA-Compatible
96
+    </FilesMatch>
97
+</IfModule>
98
+
99
+# ------------------------------------------------------------------------------
100
+# | Cookie setting from iframes                                                |
101
+# ------------------------------------------------------------------------------
102
+
103
+# Allow cookies to be set from iframes in IE.
104
+
105
+# <IfModule mod_headers.c>
106
+#   Header set P3P "policyref=\"/w3c/p3p.xml\", CP=\"IDC DSP COR ADM DEVi TAIi PSA PSD IVAi IVDi CONi HIS OUR IND CNT\""
107
+# </IfModule>
108
+
109
+# ------------------------------------------------------------------------------
110
+# | Screen flicker                                                             |
111
+# ------------------------------------------------------------------------------
112
+
113
+# Stop screen flicker in IE on CSS rollovers (this only works in
114
+# combination with the `ExpiresByType` directives for images from below).
115
+
116
+# BrowserMatch "MSIE" brokenvary=1
117
+# BrowserMatch "Mozilla/4.[0-9]{2}" brokenvary=1
118
+# BrowserMatch "Opera" !brokenvary
119
+# SetEnvIf brokenvary 1 force-no-vary
120
+
121
+
122
+# ##############################################################################
123
+# # MIME TYPES AND ENCODING                                                    #
124
+# ##############################################################################
125
+
126
+# ------------------------------------------------------------------------------
127
+# | Proper MIME types for all files                                            |
128
+# ------------------------------------------------------------------------------
129
+
130
+<IfModule mod_mime.c>
131
+
132
+  # Audio
133
+    AddType audio/mp4                                   m4a f4a f4b
134
+    AddType audio/ogg                                   oga ogg
135
+
136
+  # JavaScript
137
+    # Normalize to standard type (it's sniffed in IE anyways):
138
+    # http://tools.ietf.org/html/rfc4329#section-7.2
139
+    AddType application/javascript                      js jsonp
140
+    AddType application/json                            json
141
+
142
+  # Video
143
+    AddType video/mp4                                   mp4 m4v f4v f4p
144
+    AddType video/ogg                                   ogv
145
+    AddType video/webm                                  webm
146
+    AddType video/x-flv                                 flv
147
+
148
+  # Web fonts
149
+    AddType application/font-woff                       woff
150
+    AddType application/vnd.ms-fontobject               eot
151
+
152
+    # Browsers usually ignore the font MIME types and sniff the content,
153
+    # however, Chrome shows a warning if other MIME types are used for the
154
+    # following fonts.
155
+    AddType application/x-font-ttf                      ttc ttf
156
+    AddType font/opentype                               otf
157
+
158
+    # Make SVGZ fonts work on iPad:
159
+    # https://twitter.com/FontSquirrel/status/14855840545
160
+    AddType     image/svg+xml                           svg svgz
161
+    AddEncoding gzip                                    svgz
162
+
163
+  # Other
164
+    AddType application/octet-stream                    safariextz
165
+    AddType application/x-chrome-extension              crx
166
+    AddType application/x-opera-extension               oex
167
+    AddType application/x-shockwave-flash               swf
168
+    AddType application/x-web-app-manifest+json         webapp
169
+    AddType application/x-xpinstall                     xpi
170
+    AddType application/xml                             atom rdf rss xml
171
+    AddType image/webp                                  webp
172
+    AddType image/x-icon                                ico
173
+    AddType text/cache-manifest                         appcache manifest
174
+    AddType text/vtt                                    vtt
175
+    AddType text/x-component                            htc
176
+    AddType text/x-vcard                                vcf
177
+
178
+</IfModule>
179
+
180
+# ------------------------------------------------------------------------------
181
+# | UTF-8 encoding                                                             |
182
+# ------------------------------------------------------------------------------
183
+
184
+# Use UTF-8 encoding for anything served as `text/html` or `text/plain`.
185
+AddDefaultCharset utf-8
186
+
187
+# Force UTF-8 for certain file formats.
188
+<IfModule mod_mime.c>
189
+    AddCharset utf-8 .atom .css .js .json .rss .vtt .webapp .xml
190
+</IfModule>
191
+
192
+
193
+# ##############################################################################
194
+# # URL REWRITES                                                               #
195
+# ##############################################################################
196
+
197
+# ------------------------------------------------------------------------------
198
+# | Rewrite engine                                                             |
199
+# ------------------------------------------------------------------------------
200
+
201
+# Turning on the rewrite engine and enabling the `FollowSymLinks` option is
202
+# necessary for the following directives to work.
203
+
204
+# If your web host doesn't allow the `FollowSymlinks` option, you may need to
205
+# comment it out and use `Options +SymLinksIfOwnerMatch` but, be aware of the
206
+# performance impact: http://httpd.apache.org/docs/current/misc/perf-tuning.html#symlinks
207
+
208
+# Also, some cloud hosting services require `RewriteBase` to be set:
209
+# http://www.rackspace.com/knowledge_center/frequently-asked-question/why-is-mod-rewrite-not-working-on-my-site
210
+
211
+<IfModule mod_rewrite.c>
212
+    Options +FollowSymlinks
213
+  # Options +SymLinksIfOwnerMatch
214
+    RewriteEngine On
215
+  # RewriteBase /
216
+</IfModule>
217
+
218
+# ------------------------------------------------------------------------------
219
+# | Suppressing / Forcing the "www." at the beginning of URLs                  |
220
+# ------------------------------------------------------------------------------
221
+
222
+# The same content should never be available under two different URLs especially
223
+# not with and without "www." at the beginning. This can cause SEO problems
224
+# (duplicate content), therefore, you should choose one of the alternatives and
225
+# redirect the other one.
226
+
227
+# By default option 1 (no "www.") is activated:
228
+# http://no-www.org/faq.php?q=class_b
229
+
230
+# If you'd prefer to use option 2, just comment out all the lines from option 1
231
+# and uncomment the ones from option 2.
232
+
233
+# IMPORTANT: NEVER USE BOTH RULES AT THE SAME TIME!
234
+
235
+# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
236
+
237
+# Option 1: rewrite www.example.com → example.com
238
+
239
+<IfModule mod_rewrite.c>
240
+    RewriteCond %{HTTPS} !=on
241
+    RewriteCond %{HTTP_HOST} ^www\.(.+)$ [NC]
242
+    RewriteRule ^ http://%1%{REQUEST_URI} [R=301,L]
243
+</IfModule>
244
+
245
+# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
246
+
247
+# Option 2: rewrite example.com → www.example.com
248
+
249
+# Be aware that the following might not be a good idea if you use "real"
250
+# subdomains for certain parts of your website.
251
+
252
+# <IfModule mod_rewrite.c>
253
+#    RewriteCond %{HTTPS} !=on
254
+#    RewriteCond %{HTTP_HOST} !^www\..+$ [NC]
255
+#    RewriteRule ^ http://www.%{HTTP_HOST}%{REQUEST_URI} [R=301,L]
256
+# </IfModule>
257
+
258
+
259
+# ##############################################################################
260
+# # SECURITY                                                                   #
261
+# ##############################################################################
262
+
263
+# ------------------------------------------------------------------------------
264
+# | Content Security Policy (CSP)                                              |
265
+# ------------------------------------------------------------------------------
266
+
267
+# You can mitigate the risk of cross-site scripting and other content-injection
268
+# attacks by setting a Content Security Policy which whitelists trusted sources
269
+# of content for your site.
270
+
271
+# The example header below allows ONLY scripts that are loaded from the current
272
+# site's origin (no inline scripts, no CDN, etc). This almost certainly won't
273
+# work as-is for your site!
274
+
275
+# To get all the details you'll need to craft a reasonable policy for your site,
276
+# read: http://html5rocks.com/en/tutorials/security/content-security-policy (or
277
+# see the specification: http://w3.org/TR/CSP).
278
+
279
+# <IfModule mod_headers.c>
280
+#    Header set Content-Security-Policy "script-src 'self'; object-src 'self'"
281
+#    <FilesMatch "\.(appcache|crx|css|eot|gif|htc|ico|jpe?g|js|m4a|m4v|manifest|mp4|oex|oga|ogg|ogv|otf|pdf|png|safariextz|svg|svgz|ttf|vcf|webapp|webm|webp|woff|xml|xpi)$">
282
+#        Header unset Content-Security-Policy
283
+#    </FilesMatch>
284
+# </IfModule>
285
+
286
+# ------------------------------------------------------------------------------
287
+# | File access                                                                |
288
+# ------------------------------------------------------------------------------
289
+
290
+# Block access to directories without a default document.
291
+# Usually you should leave this uncommented because you shouldn't allow anyone
292
+# to surf through every directory on your server (which may includes rather
293
+# private places like the CMS's directories).
294
+
295
+<IfModule mod_autoindex.c>
296
+    Options -Indexes
297
+</IfModule>
298
+
299
+# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
300
+
301
+# Block access to hidden files and directories.
302
+# This includes directories used by version control systems such as Git and SVN.
303
+
304
+<IfModule mod_rewrite.c>
305
+    RewriteCond %{SCRIPT_FILENAME} -d [OR]
306
+    RewriteCond %{SCRIPT_FILENAME} -f
307
+    RewriteRule "(^|/)\." - [F]
308
+</IfModule>
309
+
310
+# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
311
+
312
+# Block access to backup and source files.
313
+# These files may be left by some text editors and can pose a great security
314
+# danger when anyone has access to them.
315
+
316
+<FilesMatch "(^#.*#|\.(bak|config|dist|fla|inc|ini|log|psd|sh|sql|sw[op])|~)$">
317
+    Order allow,deny
318
+    Deny from all
319
+    Satisfy All
320
+</FilesMatch>
321
+
322
+# ------------------------------------------------------------------------------
323
+# | Secure Sockets Layer (SSL)                                                 |
324
+# ------------------------------------------------------------------------------
325
+
326
+# Rewrite secure requests properly to prevent SSL certificate warnings, e.g.:
327
+# prevent `https://www.example.com` when your certificate only allows
328
+# `https://secure.example.com`.
329
+
330
+# <IfModule mod_rewrite.c>
331
+#    RewriteCond %{SERVER_PORT} !^443
332
+#    RewriteRule ^ https://example-domain-please-change-me.com%{REQUEST_URI} [R=301,L]
333
+# </IfModule>
334
+
335
+# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
336
+
337
+# Force client-side SSL redirection.
338
+
339
+# If a user types "example.com" in his browser, the above rule will redirect him
340
+# to the secure version of the site. That still leaves a window of opportunity
341
+# (the initial HTTP connection) for an attacker to downgrade or redirect the
342
+# request. The following header ensures that browser will ONLY connect to your
343
+# server via HTTPS, regardless of what the users type in the address bar.
344
+# http://www.html5rocks.com/en/tutorials/security/transport-layer-security/
345
+
346
+# <IfModule mod_headers.c>
347
+#    Header set Strict-Transport-Security max-age=16070400;
348
+# </IfModule>
349
+
350
+# ------------------------------------------------------------------------------
351
+# | Server software information                                                |
352
+# ------------------------------------------------------------------------------
353
+
354
+# Avoid displaying the exact Apache version number, the description of the
355
+# generic OS-type and the information about Apache's compiled-in modules.
356
+
357
+# ADD THIS DIRECTIVE IN THE `httpd.conf` AS IT WILL NOT WORK IN THE `.htaccess`!
358
+
359
+# ServerTokens Prod
360
+
361
+
362
+# ##############################################################################
363
+# # WEB PERFORMANCE                                                            #
364
+# ##############################################################################
365
+
366
+# ------------------------------------------------------------------------------
367
+# | Compression                                                                |
368
+# ------------------------------------------------------------------------------
369
+
370
+<IfModule mod_deflate.c>
371
+
372
+    # Force compression for mangled headers.
373
+    # http://developer.yahoo.com/blogs/ydn/posts/2010/12/pushing-beyond-gzipping
374
+    <IfModule mod_setenvif.c>
375
+        <IfModule mod_headers.c>
376
+            SetEnvIfNoCase ^(Accept-EncodXng|X-cept-Encoding|X{15}|~{15}|-{15})$ ^((gzip|deflate)\s*,?\s*)+|[X~-]{4,13}$ HAVE_Accept-Encoding
377
+            RequestHeader append Accept-Encoding "gzip,deflate" env=HAVE_Accept-Encoding
378
+        </IfModule>
379
+    </IfModule>
380
+
381
+    # Compress all output labeled with one of the following MIME-types
382
+    # (for Apache versions below 2.3.7, you don't need to enable `mod_filter`
383
+    #  and can remove the `<IfModule mod_filter.c>` and `</IfModule>` lines
384
+    #  as `AddOutputFilterByType` is still in the core directives).
385
+    <IfModule mod_filter.c>
386
+        AddOutputFilterByType DEFLATE application/atom+xml \
387
+                                      application/javascript \
388
+                                      application/json \
389
+                                      application/rss+xml \
390
+                                      application/vnd.ms-fontobject \
391
+                                      application/x-font-ttf \
392
+                                      application/x-web-app-manifest+json \
393
+                                      application/xhtml+xml \
394
+                                      application/xml \
395
+                                      font/opentype \
396
+                                      image/svg+xml \
397
+                                      image/x-icon \
398
+                                      text/css \
399
+                                      text/html \
400
+                                      text/plain \
401
+                                      text/x-component \
402
+                                      text/xml
403
+    </IfModule>
404
+
405
+</IfModule>
406
+
407
+# ------------------------------------------------------------------------------
408
+# | Content transformations                                                    |
409
+# ------------------------------------------------------------------------------
410
+
411
+# Prevent some of the mobile network providers from modifying the content of
412
+# your site: http://www.w3.org/Protocols/rfc2616/rfc2616-sec14.html#sec14.9.5.
413
+
414
+# <IfModule mod_headers.c>
415
+#    Header set Cache-Control "no-transform"
416
+# </IfModule>
417
+
418
+# ------------------------------------------------------------------------------
419
+# | ETag removal                                                               |
420
+# ------------------------------------------------------------------------------
421
+
422
+# Since we're sending far-future expires headers (see below), ETags can
423
+# be removed: http://developer.yahoo.com/performance/rules.html#etags.
424
+
425
+# `FileETag None` is not enough for every server.
426
+<IfModule mod_headers.c>
427
+    Header unset ETag
428
+</IfModule>
429
+
430
+FileETag None
431
+
432
+# ------------------------------------------------------------------------------
433
+# | Expires headers (for better cache control)                                 |
434
+# ------------------------------------------------------------------------------
435
+
436
+# The following expires headers are set pretty far in the future. If you don't
437
+# control versioning with filename-based cache busting, consider lowering the
438
+# cache time for resources like CSS and JS to something like 1 week.
439
+
440
+<IfModule mod_expires.c>
441
+
442
+    ExpiresActive on
443
+    ExpiresDefault                                      "access plus 1 month"
444
+
445
+  # CSS
446
+    ExpiresByType text/css                              "access plus 1 year"
447
+
448
+  # Data interchange
449
+    ExpiresByType application/json                      "access plus 0 seconds"
450
+    ExpiresByType application/xml                       "access plus 0 seconds"
451
+    ExpiresByType text/xml                              "access plus 0 seconds"
452
+
453
+  # Favicon (cannot be renamed!)
454
+    ExpiresByType image/x-icon                          "access plus 1 week"
455
+
456
+  # HTML components (HTCs)
457
+    ExpiresByType text/x-component                      "access plus 1 month"
458
+
459
+  # HTML
460
+    ExpiresByType text/html                             "access plus 0 seconds"
461
+
462
+  # JavaScript
463
+    ExpiresByType application/javascript                "access plus 1 year"
464
+
465
+  # Manifest files
466
+    ExpiresByType application/x-web-app-manifest+json   "access plus 0 seconds"
467
+    ExpiresByType text/cache-manifest                   "access plus 0 seconds"
468
+
469
+  # Media
470
+    ExpiresByType audio/ogg                             "access plus 1 month"
471
+    ExpiresByType image/gif                             "access plus 1 month"
472
+    ExpiresByType image/jpeg                            "access plus 1 month"
473
+    ExpiresByType image/png                             "access plus 1 month"
474
+    ExpiresByType video/mp4                             "access plus 1 month"
475
+    ExpiresByType video/ogg                             "access plus 1 month"
476
+    ExpiresByType video/webm                            "access plus 1 month"
477
+
478
+  # Web feeds
479
+    ExpiresByType application/atom+xml                  "access plus 1 hour"
480
+    ExpiresByType application/rss+xml                   "access plus 1 hour"
481
+
482
+  # Web fonts
483
+    ExpiresByType application/font-woff                 "access plus 1 month"
484
+    ExpiresByType application/vnd.ms-fontobject         "access plus 1 month"
485
+    ExpiresByType application/x-font-ttf                "access plus 1 month"
486
+    ExpiresByType font/opentype                         "access plus 1 month"
487
+    ExpiresByType image/svg+xml                         "access plus 1 month"
488
+
489
+</IfModule>
490
+
491
+# ------------------------------------------------------------------------------
492
+# | Filename-based cache busting                                               |
493
+# ------------------------------------------------------------------------------
494
+
495
+# If you're not using a build process to manage your filename version revving,
496
+# you might want to consider enabling the following directives to route all
497
+# requests such as `/css/style.12345.css` to `/css/style.css`.
498
+
499
+# To understand why this is important and a better idea than `*.css?v231`, read:
500
+# http://stevesouders.com/blog/2008/08/23/revving-filenames-dont-use-querystring
501
+
502
+# <IfModule mod_rewrite.c>
503
+#    RewriteCond %{REQUEST_FILENAME} !-f
504
+#    RewriteCond %{REQUEST_FILENAME} !-d
505
+#    RewriteRule ^(.+)\.(\d+)\.(js|css|png|jpg|gif)$ $1.$3 [L]
506
+# </IfModule>
507
+
508
+# ------------------------------------------------------------------------------
509
+# | File concatenation                                                         |
510
+# ------------------------------------------------------------------------------
511
+
512
+# Allow concatenation from within specific CSS and JS files, e.g.:
513
+# Inside of `script.combined.js` you could have
514
+#   <!--#include file="libs/jquery.js" -->
515
+#   <!--#include file="plugins/jquery.idletimer.js" -->
516
+# and they would be included into this single file.
517
+
518
+# <IfModule mod_include.c>
519
+#    <FilesMatch "\.combined\.js$">
520
+#        Options +Includes
521
+#        AddOutputFilterByType INCLUDES application/javascript application/json
522
+#        SetOutputFilter INCLUDES
523
+#    </FilesMatch>
524
+#    <FilesMatch "\.combined\.css$">
525
+#        Options +Includes
526
+#        AddOutputFilterByType INCLUDES text/css
527
+#        SetOutputFilter INCLUDES
528
+#    </FilesMatch>
529
+# </IfModule>
530
+
531
+# ------------------------------------------------------------------------------
532
+# | Persistent connections                                                     |
533
+# ------------------------------------------------------------------------------
534
+
535
+# Allow multiple requests to be sent over the same TCP connection:
536
+# http://httpd.apache.org/docs/current/en/mod/core.html#keepalive.
537
+
538
+# Enable if you serve a lot of static content but, be aware of the
539
+# possible disadvantages!
540
+
541
+# <IfModule mod_headers.c>
542
+#    Header set Connection Keep-Alive
543
+# </IfModule>

+ 157 - 0
app/404.html

@@ -0,0 +1,157 @@
1
+<!doctype html>
2
+<html lang="en">
3
+  <head>
4
+    <meta charset="utf-8">
5
+    <title>Page Not Found :(</title>
6
+    <style>
7
+      ::-moz-selection {
8
+        background: #b3d4fc;
9
+        text-shadow: none;
10
+      }
11
+
12
+      ::selection {
13
+        background: #b3d4fc;
14
+        text-shadow: none;
15
+      }
16
+
17
+      html {
18
+        padding: 30px 10px;
19
+        font-size: 20px;
20
+        line-height: 1.4;
21
+        color: #737373;
22
+        background: #f0f0f0;
23
+        -webkit-text-size-adjust: 100%;
24
+        -ms-text-size-adjust: 100%;
25
+      }
26
+
27
+      html,
28
+      input {
29
+        font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
30
+      }
31
+
32
+      body {
33
+        max-width: 500px;
34
+        _width: 500px;
35
+        padding: 30px 20px 50px;
36
+        border: 1px solid #b3b3b3;
37
+        border-radius: 4px;
38
+        margin: 0 auto;
39
+        box-shadow: 0 1px 10px #a7a7a7, inset 0 1px 0 #fff;
40
+        background: #fcfcfc;
41
+      }
42
+
43
+      h1 {
44
+        margin: 0 10px;
45
+        font-size: 50px;
46
+        text-align: center;
47
+      }
48
+
49
+      h1 span {
50
+        color: #bbb;
51
+      }
52
+
53
+      h3 {
54
+        margin: 1.5em 0 0.5em;
55
+      }
56
+
57
+      p {
58
+        margin: 1em 0;
59
+      }
60
+
61
+      ul {
62
+        padding: 0 0 0 40px;
63
+        margin: 1em 0;
64
+      }
65
+
66
+      .container {
67
+        max-width: 380px;
68
+        _width: 380px;
69
+        margin: 0 auto;
70
+      }
71
+
72
+      /* google search */
73
+
74
+      #goog-fixurl ul {
75
+        list-style: none;
76
+        padding: 0;
77
+        margin: 0;
78
+      }
79
+
80
+      #goog-fixurl form {
81
+        margin: 0;
82
+      }
83
+
84
+      #goog-wm-qt,
85
+      #goog-wm-sb {
86
+        border: 1px solid #bbb;
87
+        font-size: 16px;
88
+        line-height: normal;
89
+        vertical-align: top;
90
+        color: #444;
91
+        border-radius: 2px;
92
+      }
93
+
94
+      #goog-wm-qt {
95
+        width: 220px;
96
+        height: 20px;
97
+        padding: 5px;
98
+        margin: 5px 10px 0 0;
99
+        box-shadow: inset 0 1px 1px #ccc;
100
+      }
101
+
102
+      #goog-wm-sb {
103
+        display: inline-block;
104
+        height: 32px;
105
+        padding: 0 10px;
106
+        margin: 5px 0 0;
107
+        white-space: nowrap;
108
+        cursor: pointer;
109
+        background-color: #f5f5f5;
110
+        background-image: -webkit-linear-gradient(rgba(255,255,255,0), #f1f1f1);
111
+        background-image: -moz-linear-gradient(rgba(255,255,255,0), #f1f1f1);
112
+        background-image: -ms-linear-gradient(rgba(255,255,255,0), #f1f1f1);
113
+        background-image: -o-linear-gradient(rgba(255,255,255,0), #f1f1f1);
114
+        -webkit-appearance: none;
115
+        -moz-appearance: none;
116
+        appearance: none;
117
+        *overflow: visible;
118
+        *display: inline;
119
+        *zoom: 1;
120
+      }
121
+
122
+      #goog-wm-sb:hover,
123
+      #goog-wm-sb:focus {
124
+        border-color: #aaa;
125
+        box-shadow: 0 1px 1px rgba(0, 0, 0, 0.1);
126
+        background-color: #f8f8f8;
127
+      }
128
+
129
+      #goog-wm-qt:hover,
130
+      #goog-wm-qt:focus {
131
+        border-color: #105cb6;
132
+        outline: 0;
133
+        color: #222;
134
+      }
135
+
136
+      input::-moz-focus-inner {
137
+        padding: 0;
138
+        border: 0;
139
+      }
140
+    </style>
141
+  </head>
142
+  <body>
143
+    <div class="container">
144
+      <h1>Not found <span>:(</span></h1>
145
+      <p>Sorry, but the page you were trying to view does not exist.</p>
146
+      <p>It looks like this was the result of either:</p>
147
+      <ul>
148
+        <li>a mistyped address</li>
149
+        <li>an out-of-date link</li>
150
+      </ul>
151
+      <script>
152
+        var GOOG_FIXURL_LANG = (navigator.language || '').slice(0,2),GOOG_FIXURL_SITE = location.host;
153
+      </script>
154
+      <script src="//linkhelp.clients.google.com/tbproxy/lh/wm/fixurl.js"></script>
155
+    </div>
156
+  </body>
157
+</html>

BIN
app/favicon.ico


BIN
app/images/yeoman.png


+ 99 - 0
app/index.html

@@ -0,0 +1,99 @@
1
+<!doctype html>
2
+<html class="no-js">
3
+  <head>
4
+    <meta charset="utf-8">
5
+    <title></title>
6
+    <meta name="description" content="">
7
+    <meta name="viewport" content="width=device-width">
8
+    <!-- Place favicon.ico and apple-touch-icon.png in the root directory -->
9
+    <!-- build:css(.) styles/vendor.css -->
10
+    <!-- bower:css -->
11
+    <link rel="stylesheet" href="bower_components/bootstrap/dist/css/bootstrap.css" />
12
+    <link rel="stylesheet" href="bower_components/ladda/dist/ladda.min.css" />
13
+    <!-- endbower -->
14
+    <!-- endbuild -->
15
+    <!-- build:css(.tmp) styles/main.css -->
16
+    <link rel="stylesheet" href="styles/main.css">
17
+    <!-- endbuild -->
18
+  </head>
19
+  <body ng-app="domainManagerApp">
20
+    <!--[if lt IE 7]>
21
+      <p class="browsehappy">You are using an <strong>outdated</strong> browser. Please <a href="http://browsehappy.com/">upgrade your browser</a> to improve your experience.</p>
22
+    <![endif]-->
23
+
24
+    <!-- Add your site or application content here -->
25
+    <div class="header">
26
+      <div class="navbar navbar-default" role="navigation">
27
+        <div class="container">
28
+          <div class="navbar-header">
29
+
30
+            <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#js-navbar-collapse">
31
+              <span class="sr-only">Toggle navigation</span>
32
+              <span class="icon-bar"></span>
33
+              <span class="icon-bar"></span>
34
+              <span class="icon-bar"></span>
35
+            </button>
36
+
37
+            <a class="navbar-brand" href="#/">domainManager</a>
38
+          </div>
39
+
40
+          <div class="collapse navbar-collapse" id="js-navbar-collapse" ng-controller="HeaderController">
41
+
42
+            <ul class="nav navbar-nav" >
43
+              <li ng-class="{ active: isActive('/')}"><a href="#/">Home</a></li>
44
+              <li ng-class="{ active: isActive('/domains')}"><a href="#/domains">domains</a></li>
45
+              <li ng-class="{ active: isActive('/sign_in')}"><a href="#/sign_in">Sign in</a></li>
46
+            </ul>
47
+          </div>
48
+        </div>
49
+      </div>
50
+    </div>
51
+
52
+    <div class="container">
53
+    <div ng-view=""></div>
54
+    </div>
55
+
56
+    <div footer></div>
57
+
58
+
59
+    <!-- Google Analytics: change UA-XXXXX-X to be your site's ID -->
60
+     <script>
61
+       !function(A,n,g,u,l,a,r){A.GoogleAnalyticsObject=l,A[l]=A[l]||function(){
62
+       (A[l].q=A[l].q||[]).push(arguments)},A[l].l=+new Date,a=n.createElement(g),
63
+       r=n.getElementsByTagName(g)[0],a.src=u,r.parentNode.insertBefore(a,r)
64
+       }(window,document,'script','//www.google-analytics.com/analytics.js','ga');
65
+
66
+       ga('create', 'UA-XXXXX-X');
67
+       ga('send', 'pageview');
68
+    </script>
69
+
70
+    <!-- build:js(.) scripts/vendor.js -->
71
+    <!-- bower:js -->
72
+    <script src="bower_components/jquery/dist/jquery.js"></script>
73
+    <script src="bower_components/angular/angular.js"></script>
74
+    <script src="bower_components/bootstrap/dist/js/bootstrap.js"></script>
75
+    <script src="bower_components/angular-animate/angular-animate.js"></script>
76
+    <script src="bower_components/angular-cookies/angular-cookies.js"></script>
77
+    <script src="bower_components/angular-resource/angular-resource.js"></script>
78
+    <script src="bower_components/angular-route/angular-route.js"></script>
79
+    <script src="bower_components/angular-sanitize/angular-sanitize.js"></script>
80
+    <script src="bower_components/angular-touch/angular-touch.js"></script>
81
+    <script src="bower_components/firebase/firebase.js"></script>
82
+    <script src="bower_components/angularfire/dist/angularfire.js"></script>
83
+    <script src="bower_components/spin.js/spin.js"></script>
84
+    <script src="bower_components/ladda/dist/ladda.min.js"></script>
85
+    <script src="bower_components/angular-ladda/dist/angular-ladda.min.js"></script>
86
+    <!-- endbower -->
87
+    <!-- endbuild -->
88
+
89
+        <!-- build:js({.tmp,app}) scripts/scripts.js -->
90
+        <script src="scripts/app.js"></script>
91
+        <script src="scripts/controllers/main.js"></script>
92
+        <script src="scripts/controllers/domainsList.js"></script>
93
+        <script src="scripts/controllers/signin.js"></script>
94
+        <script src="scripts/controllers/header.js"></script>
95
+        <script src="scripts/directives/footer.js"></script>
96
+        <!-- endbuild -->
97
+        <scriptsrc="https://cdn.firebase.com/js/simple-login/1.6.2/firebase-simple-login.js"></script>
98
+</body>
99
+</html>

+ 3 - 0
app/robots.txt

@@ -0,0 +1,3 @@
1
+# robotstxt.org
2
+
3
+User-agent: *

+ 41 - 0
app/scripts/app.js

@@ -0,0 +1,41 @@
1
+'use strict';
2
+
3
+/**
4
+ * @ngdoc overview
5
+ * @name domainManagerApp
6
+ * @description
7
+ * # domainManagerApp
8
+ *
9
+ * Main module of the application.
10
+ */
11
+angular
12
+  .module('domainManagerApp', [
13
+    'ngAnimate',
14
+    'ngCookies',
15
+    'ngResource',
16
+    'ngRoute',
17
+    'ngSanitize',
18
+    'ngTouch',
19
+    'firebase',
20
+    'domainManagerApp.main',
21
+    'domainManagerApp.signin',
22
+    'domainManagerApp.domains'
23
+  ])
24
+  .config(['$routeProvider', function($routeProvider) {
25
+    $routeProvider
26
+      .when('/', {
27
+        templateUrl: 'views/main.html',
28
+        controller: 'MainCtrl'
29
+      })
30
+      .when('/domains', {
31
+        templateUrl: 'views/domains.html',
32
+        controller: 'DomainsListController'
33
+      })
34
+      .when('/sign_in', {
35
+        templateUrl: 'views/signin.html',
36
+        controller: 'SignInController'
37
+      })
38
+      .otherwise({
39
+        redirectTo: '/'
40
+      });
41
+  }]);

+ 18 - 0
app/scripts/controllers/domainsList.js

@@ -0,0 +1,18 @@
1
+'use strict';
2
+
3
+/**
4
+ * @ngdoc function
5
+ * @name domainManagerApp.controller:AboutCtrl
6
+ * @description
7
+ * # AboutCtrl
8
+ * Controller of the domainManagerApp
9
+ */
10
+angular.module('domainManagerApp.domains', [])
11
+  .controller('DomainsListController', function ($scope, $http) {
12
+    $http({
13
+      method: 'GET',
14
+      url: '/scripts/data.json'
15
+    }).success(function(data) {
16
+      $scope.domains = data.domains;
17
+    })
18
+  });

+ 15 - 0
app/scripts/controllers/header.js

@@ -0,0 +1,15 @@
1
+'use strict';
2
+
3
+/**
4
+ * @ngdoc function
5
+ * @name domainManagerApp.controller:MainCtrl
6
+ * @description
7
+ * # MainCtrl
8
+ * Controller of the domainManagerApp
9
+ */
10
+angular.module('domainManagerApp')
11
+  .controller('HeaderController', function ($scope, $location) {
12
+    $scope.isActive = function (viewLocation) {
13
+        return viewLocation === $location.path();
14
+    };
15
+  });

+ 17 - 0
app/scripts/controllers/main.js

@@ -0,0 +1,17 @@
1
+'use strict';
2
+
3
+/**
4
+ * @ngdoc function
5
+ * @name domainManagerApp.controller:MainCtrl
6
+ * @description
7
+ * # MainCtrl
8
+ * Controller of the domainManagerApp
9
+ */
10
+ angular.module('domainManagerApp.main', ['firebase'])
11
+  .controller('MainCtrl', function ($scope) {
12
+    $scope.awesomeThings = [
13
+      'HTML5 Boilerplate',
14
+      'AngularJS',
15
+      'Karma'
16
+    ];
17
+  });

+ 30 - 0
app/scripts/controllers/signin.js

@@ -0,0 +1,30 @@
1
+'use strict';
2
+
3
+/**
4
+ * @ngdoc function
5
+ * @name domainManagerApp.controller:MainCtrl
6
+ * @description
7
+ * # MainCtrl
8
+ * Controller of the domainManagerApp
9
+ */
10
+ angular.module('domainManagerApp.signin', ['firebase'])
11
+ .controller('SignInController', ['$scope', '$firebaseAuth', function ($scope, $firebaseAuth) {
12
+
13
+    var firebaseObj = new Firebase("https://j1x-cpanel.firebaseio.com");
14
+    $scope.authObj = $firebaseAuth(firebaseObj);
15
+
16
+    $scope.SignIn = function(event) {
17
+      event.preventDefault();  // To prevent form refresh
18
+      var username = $scope.user.email;
19
+      var password = $scope.user.password;
20
+
21
+      $scope.authObj.$authWithPassword({
22
+        email: username,
23
+        password: password
24
+      }).then(function(authData) {
25
+        console.log("Logged in as:", authData.uid);
26
+      }).catch(function(error) {
27
+        console.error("Authentication failed:", error);
28
+      });
29
+    }
30
+  }]);

+ 36 - 0
app/scripts/data.json

@@ -0,0 +1,36 @@
1
+{
2
+  "domains" : [
3
+     {
4
+       "name"   : "jamesperet.com",
5
+       "status" : "OK",
6
+       "owner"  : "James Peret",
7
+       "registrart" : "NT10",
8
+       "registration_date" : "",
9
+       "expiration_date"   : ""
10
+     },
11
+     {
12
+       "name"   : "jamesperet.com.br",
13
+       "status" : "OK",
14
+       "owner"  : "James Peret",
15
+       "registrart" : "NT10",
16
+       "registration_date" : "",
17
+       "expiration_date"   : ""
18
+     },
19
+     {
20
+       "name"   : "higheffects.com",
21
+       "status" : "OK",
22
+       "owner"  : "James Peret",
23
+       "registrart" : "NT10",
24
+       "registration_date" : "",
25
+       "expiration_date"   : ""
26
+     },
27
+     {
28
+       "name"   : "higheffects.com.br",
29
+       "status" : "OK",
30
+       "owner"  : "James Peret",
31
+       "registrart" : "NT10",
32
+       "registration_date" : "",
33
+       "expiration_date"   : ""
34
+     }
35
+  ]
36
+}

+ 11 - 0
app/scripts/directives/footer.js

@@ -0,0 +1,11 @@
1
+angular.module('domainManagerApp')
2
+  .directive('footer', function () {
3
+      return {
4
+          restrict: 'A', //This menas that it will be used as an attribute and NOT as an element. I don't like creating custom HTML elements
5
+          replace: true,
6
+          templateUrl: "../../views/footer.html",
7
+          controller: ['$scope', '$filter', function ($scope, $filter) {
8
+              // code goes here
9
+          }]
10
+      }
11
+  });

+ 139 - 0
app/styles/main.css

@@ -0,0 +1,139 @@
1
+.browsehappy {
2
+  margin: 0.2em 0;
3
+  background: #ccc;
4
+  color: #000;
5
+  padding: 0.2em 0;
6
+}
7
+
8
+body {
9
+  padding: 0;
10
+  background-color: #eee;
11
+}
12
+
13
+body.ng-scope {padding: 0px;}
14
+
15
+/* Everything but the jumbotron gets side spacing for mobile first views */
16
+.header,
17
+.marketing,
18
+.footer {
19
+  padding-left: 15px;
20
+  padding-right: 15px;
21
+}
22
+
23
+/* Custom page header */
24
+.header {
25
+  border-bottom: 1px solid #e5e5e5;
26
+  margin-bottom: 10px;
27
+}
28
+/* Make the masthead heading the same height as the navigation */
29
+.header h3 {
30
+  margin-top: 0;
31
+  margin-bottom: 0;
32
+  line-height: 40px;
33
+  padding-bottom: 19px;
34
+}
35
+
36
+/* Custom page footer */
37
+.footer {
38
+  padding-top: 19px;
39
+  color: #777;
40
+  border-top: 1px solid #e5e5e5;
41
+}
42
+
43
+.container-narrow > hr {
44
+  margin: 30px 0;
45
+}
46
+
47
+/* Main marketing message and sign up button */
48
+.jumbotron {
49
+  text-align: center;
50
+  border-bottom: 1px solid #e5e5e5;
51
+}
52
+.jumbotron .btn {
53
+  font-size: 21px;
54
+  padding: 14px 24px;
55
+}
56
+
57
+/* Supporting marketing content */
58
+.marketing {
59
+  margin: 40px 0;
60
+}
61
+.marketing p + h4 {
62
+  margin-top: 28px;
63
+}
64
+
65
+/* Responsive: Portrait tablets and up */
66
+@media screen and (min-width: 768px) {
67
+  .container {
68
+    max-width: 730px;
69
+  }
70
+
71
+  /* Remove the padding we set earlier */
72
+  .header,
73
+  .marketing,
74
+  .footer {
75
+    padding-left: 0;
76
+    padding-right: 0;
77
+  }
78
+  /* Space out the masthead */
79
+  .header {
80
+    margin-bottom: 30px;
81
+  }
82
+  /* Remove the bottom border on the jumbotron for visual effect */
83
+  .jumbotron {
84
+    border-bottom: 0;
85
+    margin-bottom: 0px;
86
+    padding-top: 10px;
87
+  }
88
+}
89
+
90
+/* Bootstrap Signup Styles */
91
+
92
+.form-signin {
93
+  max-width: 330px;
94
+  padding: 15px;
95
+  margin: 0 auto;
96
+  margin-bottom: 45px;
97
+}
98
+.form-signin .form-signin-heading,
99
+.form-signin .checkbox {
100
+  margin-bottom: 10px;
101
+}
102
+.form-signin .checkbox {
103
+  font-weight: normal;
104
+}
105
+.form-signin .form-control {
106
+  position: relative;
107
+  height: auto;
108
+  -webkit-box-sizing: border-box;
109
+     -moz-box-sizing: border-box;
110
+          box-sizing: border-box;
111
+  padding: 10px;
112
+  font-size: 16px;
113
+}
114
+.form-signin .form-control:focus {
115
+  z-index: 2;
116
+}
117
+.form-signin input[type="email"] {
118
+  margin-bottom: -1px;
119
+  border-bottom-right-radius: 0;
120
+  border-bottom-left-radius: 0;
121
+}
122
+.form-signin input[type="password"] {
123
+  margin-bottom: 10px;
124
+  border-top-left-radius: 0;
125
+  border-top-right-radius: 0;
126
+}
127
+
128
+h1.j1x-logo {
129
+  text-transform: uppercase;
130
+  font-weight: 600;
131
+  font-size: 120px;
132
+  margin-bottom: 0px;
133
+}
134
+
135
+.form-title {
136
+  text-align: center;
137
+  margin-bottom: 20px;
138
+  margin-top: 0px;
139
+}

+ 3 - 0
app/views/domains.html

@@ -0,0 +1,3 @@
1
+<ul>
2
+  <li ng-repeat="domain in domains">{{domain.name}}</li>
3
+</ul>

+ 5 - 0
app/views/footer.html

@@ -0,0 +1,5 @@
1
+<div class="footer">
2
+  <div class="container">
3
+    <p><span class="glyphicon glyphicon-heart"></span> from the Yeoman team</p>
4
+  </div>
5
+</div>

+ 8 - 0
app/views/main.html

@@ -0,0 +1,8 @@
1
+<div class="container">
2
+    <div class="jumbotron" style="padding-bottom:15px;">
3
+        <h1 class="j1x-logo">J1X</h1>
4
+        <h2>Domain Manager</h2>
5
+    </div>
6
+
7
+
8
+</div>

+ 13 - 0
app/views/signin.html

@@ -0,0 +1,13 @@
1
+<div class="container">
2
+    <div class="jumbotron" style="padding-bottom:15px;">
3
+        <h1 class="j1x-logo">J1X</h1>
4
+
5
+    </div>
6
+    <form class="form-signin" role="form">
7
+        <h2 class="form-title">Login</h2>
8
+        <input ng-model="user.email" type="email" class="form-control" placeholder="Email address" required="" autofocus="">
9
+        <input ng-model="user.password" type="password" class="form-control" placeholder="Password" required="">
10
+        <button type="button" ng-click="SignIn($event)" class="btn btn-lg btn-primary btn-block">SignIn</button>
11
+  </form>
12
+
13
+</div>

+ 21 - 0
bower.json

@@ -0,0 +1,21 @@
1
+{
2
+  "name": "domain-manager",
3
+  "version": "0.0.0",
4
+  "dependencies": {
5
+    "angular": "^1.3.0",
6
+    "bootstrap": "^3.2.0",
7
+    "angular-animate": "^1.3.0",
8
+    "angular-cookies": "^1.3.0",
9
+    "angular-resource": "^1.3.0",
10
+    "angular-route": "^1.3.0",
11
+    "angular-sanitize": "^1.3.0",
12
+    "angular-touch": "^1.3.0",
13
+    "angularfire": "~1.1.1",
14
+    "angular-ladda": "~0.2.2"
15
+  },
16
+  "devDependencies": {
17
+    "angular-mocks": "^1.3.0"
18
+  },
19
+  "appPath": "app",
20
+  "moduleName": "domainManagerApp"
21
+}

+ 41 - 0
package.json

@@ -0,0 +1,41 @@
1
+{
2
+  "name": "domainmanager",
3
+  "version": "0.0.0",
4
+  "dependencies": {},
5
+  "repository": {},
6
+  "devDependencies": {
7
+    "grunt": "^0.4.5",
8
+    "grunt-autoprefixer": "^2.0.0",
9
+    "grunt-concurrent": "^1.0.0",
10
+    "grunt-contrib-clean": "^0.6.0",
11
+    "grunt-contrib-concat": "^0.5.0",
12
+    "grunt-contrib-connect": "^0.9.0",
13
+    "grunt-contrib-copy": "^0.7.0",
14
+    "grunt-contrib-cssmin": "^0.12.0",
15
+    "grunt-contrib-htmlmin": "^0.4.0",
16
+    "grunt-contrib-imagemin": "^0.9.2",
17
+    "grunt-contrib-jshint": "^0.11.0",
18
+    "grunt-contrib-uglify": "^0.7.0",
19
+    "grunt-contrib-watch": "^0.6.1",
20
+    "grunt-filerev": "^2.1.2",
21
+    "grunt-google-cdn": "^0.4.3",
22
+    "grunt-karma": "*",
23
+    "grunt-newer": "^1.1.0",
24
+    "grunt-ng-annotate": "^0.9.2",
25
+    "grunt-svgmin": "^2.0.0",
26
+    "grunt-usemin": "^3.0.0",
27
+    "grunt-wiredep": "^2.0.0",
28
+    "jshint": "^2.7.0",
29
+    "jshint-stylish": "^1.0.0",
30
+    "karma-jasmine": "*",
31
+    "karma-phantomjs-launcher": "*",
32
+    "load-grunt-tasks": "^3.1.0",
33
+    "time-grunt": "^1.0.0"
34
+  },
35
+  "engines": {
36
+    "node": ">=0.10.0"
37
+  },
38
+  "scripts": {
39
+    "test": "grunt test"
40
+  }
41
+}

+ 28 - 0
test/.jshintrc

@@ -0,0 +1,28 @@
1
+{
2
+  "node": true,
3
+  "browser": true,
4
+  "esnext": true,
5
+  "bitwise": true,
6
+  "camelcase": true,
7
+  "curly": true,
8
+  "eqeqeq": true,
9
+  "immed": true,
10
+  "indent": 2,
11
+  "latedef": true,
12
+  "newcap": true,
13
+  "noarg": true,
14
+  "quotmark": "single",
15
+  "regexp": true,
16
+  "undef": true,
17
+  "unused": true,
18
+  "strict": true,
19
+  "trailing": true,
20
+  "smarttabs": true,
21
+  "jasmine": true,
22
+  "globals": {
23
+    "angular": false,
24
+    "browser": false,
25
+    "inject": false
26
+  }
27
+}
28
+

+ 88 - 0
test/karma.conf.js

@@ -0,0 +1,88 @@
1
+// Karma configuration
2
+// http://karma-runner.github.io/0.12/config/configuration-file.html
3
+// Generated on 2015-05-16 using
4
+// generator-karma 1.0.0
5
+
6
+module.exports = function(config) {
7
+  'use strict';
8
+
9
+  config.set({
10
+    // enable / disable watching file and executing tests whenever any file changes
11
+    autoWatch: true,
12
+
13
+    // base path, that will be used to resolve files and exclude
14
+    basePath: '../',
15
+
16
+    // testing framework to use (jasmine/mocha/qunit/...)
17
+    // as well as any additional frameworks (requirejs/chai/sinon/...)
18
+    frameworks: [
19
+      "jasmine"
20
+    ],
21
+
22
+    // list of files / patterns to load in the browser
23
+    files: [
24
+      // bower:js
25
+      'bower_components/jquery/dist/jquery.js',
26
+      'bower_components/angular/angular.js',
27
+      'bower_components/bootstrap/dist/js/bootstrap.js',
28
+      'bower_components/angular-animate/angular-animate.js',
29
+      'bower_components/angular-cookies/angular-cookies.js',
30
+      'bower_components/angular-resource/angular-resource.js',
31
+      'bower_components/angular-route/angular-route.js',
32
+      'bower_components/angular-sanitize/angular-sanitize.js',
33
+      'bower_components/angular-touch/angular-touch.js',
34
+      'bower_components/firebase/firebase.js',
35
+      'bower_components/angularfire/dist/angularfire.js',
36
+      'bower_components/spin.js/spin.js',
37
+      'bower_components/ladda/dist/ladda.min.js',
38
+      'bower_components/angular-ladda/dist/angular-ladda.min.js',
39
+      'bower_components/angular-mocks/angular-mocks.js',
40
+      // endbower
41
+      "app/scripts/**/*.js",
42
+      "test/mock/**/*.js",
43
+      "test/spec/**/*.js"
44
+    ],
45
+
46
+    // list of files / patterns to exclude
47
+    exclude: [
48
+    ],
49
+
50
+    // web server port
51
+    port: 8080,
52
+
53
+    // Start these browsers, currently available:
54
+    // - Chrome
55
+    // - ChromeCanary
56
+    // - Firefox
57
+    // - Opera
58
+    // - Safari (only Mac)
59
+    // - PhantomJS
60
+    // - IE (only Windows)
61
+    browsers: [
62
+      "PhantomJS"
63
+    ],
64
+
65
+    // Which plugins to enable
66
+    plugins: [
67
+      "karma-phantomjs-launcher",
68
+      "karma-jasmine"
69
+    ],
70
+
71
+    // Continuous Integration mode
72
+    // if true, it capture browsers, run tests and exit
73
+    singleRun: false,
74
+
75
+    colors: true,
76
+
77
+    // level of logging
78
+    // possible values: LOG_DISABLE || LOG_ERROR || LOG_WARN || LOG_INFO || LOG_DEBUG
79
+    logLevel: config.LOG_INFO,
80
+
81
+    // Uncomment the following lines if you are using grunt's server to run the tests
82
+    // proxies: {
83
+    //   '/': 'http://localhost:9000/'
84
+    // },
85
+    // URL root prevent conflicts with the site root
86
+    // urlRoot: '_karma_'
87
+  });
88
+};

+ 22 - 0
test/spec/controllers/about.js

@@ -0,0 +1,22 @@
1
+'use strict';
2
+
3
+describe('Controller: AboutCtrl', function () {
4
+
5
+  // load the controller's module
6
+  beforeEach(module('domainManagerApp'));
7
+
8
+  var AboutCtrl,
9
+    scope;
10
+
11
+  // Initialize the controller and a mock scope
12
+  beforeEach(inject(function ($controller, $rootScope) {
13
+    scope = $rootScope.$new();
14
+    AboutCtrl = $controller('AboutCtrl', {
15
+      $scope: scope
16
+    });
17
+  }));
18
+
19
+  it('should attach a list of awesomeThings to the scope', function () {
20
+    expect(scope.awesomeThings.length).toBe(3);
21
+  });
22
+});

+ 22 - 0
test/spec/controllers/main.js

@@ -0,0 +1,22 @@
1
+'use strict';
2
+
3
+describe('Controller: MainCtrl', function () {
4
+
5
+  // load the controller's module
6
+  beforeEach(module('domainManagerApp'));
7
+
8
+  var MainCtrl,
9
+    scope;
10
+
11
+  // Initialize the controller and a mock scope
12
+  beforeEach(inject(function ($controller, $rootScope) {
13
+    scope = $rootScope.$new();
14
+    MainCtrl = $controller('MainCtrl', {
15
+      $scope: scope
16
+    });
17
+  }));
18
+
19
+  it('should attach a list of awesomeThings to the scope', function () {
20
+    expect(scope.awesomeThings.length).toBe(3);
21
+  });
22
+});