@@ -0,0 +1,3 @@ |
||
1 |
+{ |
|
2 |
+ "directory": "bower_components" |
|
3 |
+} |
@@ -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 |
@@ -0,0 +1 @@ |
||
1 |
+* text=auto |
@@ -0,0 +1,5 @@ |
||
1 |
+node_modules |
|
2 |
+dist |
|
3 |
+.tmp |
|
4 |
+.sass-cache |
|
5 |
+bower_components |
@@ -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 |
+} |
@@ -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' |
@@ -0,0 +1 @@ |
||
1 |
+{} |
@@ -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 |
+}; |
@@ -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. |
@@ -0,0 +1 @@ |
||
1 |
+*.coffee |
@@ -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> |
@@ -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> |
@@ -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> |
@@ -0,0 +1,3 @@ |
||
1 |
+# robotstxt.org |
|
2 |
+ |
|
3 |
+User-agent: * |
@@ -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 |
+ }]); |
@@ -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 |
+ }); |
@@ -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 |
+ }); |
@@ -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 |
+ }); |
@@ -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 |
+ }]); |
@@ -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 |
+} |
@@ -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 |
+ }); |
@@ -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 |
+} |
@@ -0,0 +1,3 @@ |
||
1 |
+<ul> |
|
2 |
+ <li ng-repeat="domain in domains">{{domain.name}}</li> |
|
3 |
+</ul> |
@@ -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> |
@@ -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> |
@@ -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> |
@@ -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 |
+} |
@@ -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 |
+} |
@@ -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 |
+ |
@@ -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 |
+}; |
@@ -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 |
+}); |
@@ -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 |
+}); |