{"id":14967748,"url":"https://github.com/justsml/angular-material-es6-example","last_synced_at":"2025-07-24T20:37:28.355Z","repository":{"id":141957343,"uuid":"50757558","full_name":"justsml/angular-material-es6-example","owner":"justsml","description":"Example Music Player App feat. Sails.js, ES6, Angular (v1.x), Jade, Gulp, Browserify, Babel, and Material Design","archived":false,"fork":false,"pushed_at":"2017-06-01T21:07:31.000Z","size":32194,"stargazers_count":13,"open_issues_count":0,"forks_count":3,"subscribers_count":4,"default_branch":"master","last_synced_at":"2025-04-07T10:25:05.825Z","etag":null,"topics":["angular","babel","browserify","jade","material","music-player","sailsjs"],"latest_commit_sha":null,"homepage":"","language":"JavaScript","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"mit","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/justsml.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":"LICENSE","code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null}},"created_at":"2016-01-31T03:46:37.000Z","updated_at":"2023-12-22T08:15:30.000Z","dependencies_parsed_at":null,"dependency_job_id":"ea048137-0667-4e1b-aede-ae1992ca7dfb","html_url":"https://github.com/justsml/angular-material-es6-example","commit_stats":{"total_commits":48,"total_committers":3,"mean_commits":16.0,"dds":0.0625,"last_synced_commit":"62b192df98ef34ee11176139c1e9261a89159ed2"},"previous_names":[],"tags_count":0,"template":false,"template_full_name":null,"purl":"pkg:github/justsml/angular-material-es6-example","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/justsml%2Fangular-material-es6-example","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/justsml%2Fangular-material-es6-example/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/justsml%2Fangular-material-es6-example/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/justsml%2Fangular-material-es6-example/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/justsml","download_url":"https://codeload.github.com/justsml/angular-material-es6-example/tar.gz/refs/heads/master","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/justsml%2Fangular-material-es6-example/sbom","host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":266902922,"owners_count":24003791,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2022-07-04T15:15:14.044Z","status":"online","status_checked_at":"2025-07-24T02:00:09.469Z","response_time":99,"last_error":null,"robots_txt_status":"success","robots_txt_updated_at":"2025-07-24T06:49:26.215Z","robots_txt_url":"https://github.com/robots.txt","online":true,"can_crawl_api":true,"host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["angular","babel","browserify","jade","material","music-player","sailsjs"],"created_at":"2024-09-24T13:38:33.166Z","updated_at":"2025-07-24T20:37:28.326Z","avatar_url":"https://github.com/justsml.png","language":"JavaScript","funding_links":[],"categories":[],"sub_categories":[],"readme":"# jsbeats - Music Player Demo Project\n\n## Screenshot\n\n![jsbeats-split-screen-playlist](https://raw.githubusercontent.com/justsml/angular-material-es6-example/master/assets/images/jsbeats-split-screen-playlist.png)\n\n## Technology\n\n* [NodeJS](https://nodejs.org/)\n* [ES6/ES2015](http://www.2ality.com/2014/09/es6-modules-final.html)\n* [Babel](http://babeljs.io/) - [es2015](http://babeljs.io/docs/plugins/preset-es2015/) \u0026 [stage0](http://babeljs.io/docs/plugins/preset-stage-0/) plugins\n* [Angular v1.x](https://docs.angularjs.org/guide)\n* [Express JS](http://expressjs.com/en/4x/api.html)\n* [Sails.js](http://sailsjs.org/documentation/reference/) (REST API)\n* [Browserify](http://browserify.org/)\n* [Angular Material](https://material.angularjs.org/) (Google's Material Design)\n* [Gulp](https://github.com/gulpjs/gulp)\n* [Jade](http://jade-lang.com/) - [Jadeify](https://github.com/domenic/jadeify)\n* [Audio5](https://github.com/zohararad/audio5js)\n\n\u003e Note: React version in the works. Angular v2 after that.\n\n## Features\n\n* [x] File upload [sailsjs details](http://sailsjs.org/documentation/reference/request-req/req-file)\n* [x] Add music form, title, artist, album, file\n* [x] Queue/playlist, displays title, artist, album\n* [x] Double-clicking in queue list plays selected song\n* [x] When a song finishes playing, play next song in queue\n* [x] Player status: current song title, artist, album, time elapsed, duration\n* [x] Player interface: play, stop, previous, next, scrubber bar, should all actually function.\n* [x] Actually playing audio.\n* [x] Simple UI theme in CSS.\n* [x] Persistence using **REST API**.\n* [x] Dummy data loader (set to auto initialize data)\n\n## Run the Project\n\n\u003e Develped \u0026 Tested on Debian 8\n\n```sh\ngit clone https://github.com/justsml/angular-material-es6-example.git\ncd angular-material-es6-example\nnpm install\nnpm run build\nnpm start\n```\n\n\u003e Then visit: [http://localhost:1337/](http://localhost:1337/)\n\n## Run with Docker\n\n```sh\nnpm run docker-build\nnpm run docker-run\n\n# Or to mount the local dev folder for live updating (no `docker build` needed for every change)\nnpm run docker-run-dev\n\n```\n\n\u003e Then visit: [http://localhost:1337/](http://localhost:1337/)\n\n\n## Schemas\n\n* Media\n  * `Title`\n  * `Artist`\n  * `Album`\n  * `AudioUrl`\n* Playlist\n  * `Title`\n  * `Tracks[Media]`\n\n## CREDIT \u0026 REFERENCES\n\n* [Exploring ES6 Patterns for Angular v1.0](http://www.michaelbromley.co.uk/blog/350/exploring-es6-classes-in-angularjs-1-x%20nice)\n* [Angular \u0026 Material Design Info](https://scotch.io/bar-talk/angular-material-vs-material-design-lite)\n* [ES6 Module Info](http://www.2ality.com/2014/09/es6-modules-final.html)\n* [REST API built using SailsJS](https://www.smashingmagazine.com/2015/11/sailing-sails-js-mvc-style-framework-node-js/)\n\n### Sample MP3 Files - Credits\n\n* [https://soundcloud.com/trapmusic/fuzzy-peach-by-brillz-minxx](https://soundcloud.com/trapmusic/fuzzy-peach-by-brillz-minxx)\n* [https://soundcloud.com/trapmusic/hydraulix-oski-lets-play](https://soundcloud.com/trapmusic/hydraulix-oski-lets-play)\n* [https://soundcloud.com/dubpolice/subscape-shanghai](https://soundcloud.com/dubpolice/subscape-shanghai)\n\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fjustsml%2Fangular-material-es6-example","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fjustsml%2Fangular-material-es6-example","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fjustsml%2Fangular-material-es6-example/lists"}