{"id":14976534,"url":"https://github.com/weihanchen/angular-screenshot","last_synced_at":"2025-10-27T20:32:13.876Z","repository":{"id":53821680,"uuid":"85822335","full_name":"weihanchen/angular-screenshot","owner":"weihanchen","description":"Angularjs directive for screen capture.","archived":false,"fork":false,"pushed_at":"2018-12-04T15:00:15.000Z","size":1430,"stargazers_count":35,"open_issues_count":5,"forks_count":12,"subscribers_count":7,"default_branch":"master","last_synced_at":"2025-02-01T08:06:30.954Z","etag":null,"topics":["angular","capture","cssnext","es6","karma","postcss","screenshot","webpack2"],"latest_commit_sha":null,"homepage":"https://weihanchen.github.io/angular-screenshot/","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/weihanchen.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}},"created_at":"2017-03-22T11:59:23.000Z","updated_at":"2024-07-01T03:42:07.000Z","dependencies_parsed_at":"2022-08-22T01:01:03.812Z","dependency_job_id":null,"html_url":"https://github.com/weihanchen/angular-screenshot","commit_stats":null,"previous_names":[],"tags_count":12,"template":false,"template_full_name":null,"repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/weihanchen%2Fangular-screenshot","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/weihanchen%2Fangular-screenshot/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/weihanchen%2Fangular-screenshot/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/weihanchen%2Fangular-screenshot/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/weihanchen","download_url":"https://codeload.github.com/weihanchen/angular-screenshot/tar.gz/refs/heads/master","host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":238523988,"owners_count":19486602,"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","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","capture","cssnext","es6","karma","postcss","screenshot","webpack2"],"created_at":"2024-09-24T13:54:02.286Z","updated_at":"2025-10-27T20:32:08.286Z","avatar_url":"https://github.com/weihanchen.png","language":"JavaScript","readme":"# angular-screenshot\n\n[![Build Status](https://travis-ci.org/weihanchen/angular-screenshot.svg?branch=master)](https://travis-ci.org/weihanchen/angular-screenshot)\n[![Coverage Status](https://coveralls.io/repos/github/weihanchen/angular-screenshot/badge.svg)](https://coveralls.io/github/weihanchen/angular-screenshot)\n[![dependencies Status](https://david-dm.org/weihanchen/angular-screenshot/status.svg)](https://david-dm.org/weihanchen/angular-screenshot)\n[![npm](https://img.shields.io/npm/v/angular-screenshot.svg?style=flat)](https://img.shields.io/npm/v/angular-screenshot.svg?style=flat)\n\nAngular screenshot in directive for screen capture.\n\nCheck out the homepage at [https://weihanchen.github.io/angular-screenshot/](https://weihanchen.github.io/angular-screenshot/)\n\n## Installation\nGet angular screenshot from bower, npm, or git.\n```\n$npm install angular-screenshot\n$bower install angular-screenshot\n$git clone https://github.com/weihanchen/angular-screenshot.git\n```\n\nAdd dependencies to the section of your index.html\n```html\n\u003cmeta charset=\"utf-8\"\u003e  \n\u003clink href=\"node_modules/angular-screenshot/build/angular-screenshot.min.css\" rel=\"stylesheet\" /\u003e\n\u003cscript src=\"node_modules/jquery/dist/jquery.min.js\"\u003e\u003c/script\u003e\n\u003cscript src=\"node_modules/angular/angular.min.js\"\u003e\u003c/script\u003e\n\u003cscript src=\"node_modules/angular-screenshot/build/angular-screenshot.min.js\"\u003e\u003c/script\u003e\n```\n\nAdd angular-screenshot dependency to module:\n```javascript\nangular.module(\"app\", [\"angular-screenshot\"])\n```\n\n## Options\n| Property       | Default       \t\t| Description  |  Sample  |\n| -------------  | ------------- \t\t| ------------:| ----\t|\n| target      \t  | element.children()  | Use target element with capture section. | `\u003cscreenshot target=\"root\"\u003e\u003cscreenshot\u003e` |\n| isOpen      \t  | false      \t\t   | Flag indicating that open the capture canvas. | `\u003cscreenshot target=\"{{::'#root'}}\" isOpen=\"appCtrl.isOpen\"\u003e\u003cscreenshot\u003e` |\n| toolboxOptions | {\"filename\": \"screenshot.png\", \"cancelText\": \"cancel\", \"downloadText\": \"download\"} | options of screenshot toolbox | `\u003cscreenshot target=\"root\" isOpen=\"appCtrl.isOpen\" toolbox-options=\"appCtrl.toolboxOptions\"\u003e\u003cscreenshot\u003e` |\n| api \t\t\t  | {\"download\": download, \"cancel\": cancel, \"downloadFull\": downloadFull, \"toPng\": toPng} | Expose api to interactive custom template action. | `\u003cscreenshot target=\"root\" isOpen=\"appCtrl.isOpen\" toolbox-options=\"appCtrl.toolbarOptions\" api=\"appCtrl.api\"\u003e\u003cscreenshot\u003e` |\n\n\n## Basic Usage\n\n### Use screenshot as element or attribute, then use default template and cover children elements default\n```html\n\u003cbutton class=\"btn btn-fab\" ng-class=\"{true: 'btn-danger', false: 'btn-default'}[appCtrl.isBasicOpen]\" ng-click=\"appCtrl.isBasicOpen = !appCtrl.isBasicOpen\"\u003e\n\t\u003ci ng-if=\"!appCtrl.isBasicOpen\" class=\"material-icons\"\u003ecrop\u003c/i\u003e\n\t\u003ci ng-if=\"appCtrl.isBasicOpen\" class=\"material-icons\"\u003eclose\u003c/i\u003e\n\u003c/button\u003e\n\u003c!--screenshot--\u003e\n\u003cscreenshot is-open=\"appCtrl.isBasicOpen\"\u003e\n\t\u003cdiv class=\"panel-body\"\u003e\n\t\t...\n\t\u003c/div\u003e\n\u003c/screenshot\u003e\n```\n\n### Use target parameter to set screenshot section on element\n```html\n\u003cdiv id=\"target1\" class=\"panel panel-info\"\u003e\n\t...\n\t\u003cdiv class=\"panel-body\"\u003e\n\t\t\u003cscreenshot target=\"{{::'#target1'}}\" is-open=\"appCtrl.target1Open\" toolbox-options=\"appCtrl.target1Options\"\u003e\u003c/screenshot\u003e\n\t\t\t...\n\t\u003c/div\u003e\n\u003c/div\u003e\n```\n```javascript\n'use strict';\n(function () {\nangular.module('app', ['angular-screenshot'])\n.controller('AppController', ['$scope', appController]);\n\tfunction appController($scope) {\n\t\tvar self = this;\n\t\tself.target1Options = {\n\t\t\tfilename: 'target1.png',\n\t\t\tdownloadText: 'Download me',\n\t\t\tcancelText: 'Close it!'\n\t\t};\n\t}\n})()\n```\n\n## Advanced usage\n### Use `screenshot-toolbox` to customize your toolbox, then use expose api to interactive with directive.\n```html\n\u003cscreenshot is-open=\"appCtrl.isAdvanceOpen\" api=\"appCtrl.advanceApi\"\u003e\n\t\u003cscreenshot-toolbox\u003e\n\t\u003cdiv class=\"btn-group-sm\"\u003e\n\t\t\u003cbutton class=\"btn btn-default btn-fab\" ng-click=\"appCtrl.cancel()\"\u003e\n\t\t\t\u003ci class=\"material-icons\"\u003eclose\u003c/i\u003e\n\t\t\u003c/button\u003e\n\t\t\u003cbutton class=\"btn btn-success btn-fab\" ng-click=\"appCtrl.download()\"\u003e\n\t\t\t\u003ci class=\"material-icons\"\u003echeck\u003c/i\u003e\n\t\t\u003c/button\u003e\n\t\u003c/div\u003e\n\t\u003c/screenshot-toolbox\u003e\n\t\u003cdiv class=\"panel-body\"\u003e\n\t\t...\n\t\u003c/div\u003e\n\u003c/screenshot\u003e\n```\n```javascript\n 'use strict';\n(function () {\n\tangular.module('app', ['angular-screenshot'])\n\t\t.controller('AppController', ['$scope', appController])\n\t\tfunction appController() {\n\t\t\tvar self = this;\n\t\t\tself.advanceApi;\n\t\t\tself.cancel = cancel;\n\t\t\tself.download = download;\n\t\tfunction cancel() {\n\t\t\tif (self.advanceApi) self.advanceApi.cancel();\n\t\t}\n\t\tfunction download() {\n\t\t\tif (self.advanceApi) self.advanceApi.download();\n\t\t}\n})();\n```\n\n ### Use screenshot as element or attribute, then use expose api to download full dom content\n ```html\n \u003cbutton class=\"btn btn-fab\" ng-class=\"{true: 'btn-danger', false: 'btn-default'}[appCtrl.isFullOpen]\" ng-click=\"appCtrl.isFullOpen = !appCtrl.isFullOpen\"\u003e\n\t\u003ci ng-if=\"!appCtrl.isFullOpen\" class=\"material-icons\"\u003ecrop\u003c/i\u003e\n\t\u003ci ng-if=\"appCtrl.isFullOpen\" class=\"material-icons\"\u003eclose\u003c/i\u003e\n\u003c/button\u003e\n\t\u003cbutton class=\"btn btn-fab\" ng-if=\"appCtrl.isFullOpen\" ng-click=\"appCtrl.downloadFull()\"\u003e\n\t\u003ci class=\"material-icons\"\u003efile_download\u003c/i\u003e\n\u003c/button\u003e\n\t\u003c!--screenshot--\u003e\n\u003cscreenshot is-open=\"appCtrl.isFullOpen\"api=\"appCtrl.fullScreenApi\" \u003e\n\t\u003cdiv class=\"panel-body\"\u003e\n\t...\n\t\u003c/div\u003e\n\u003c/screenshot\u003e\n ```\n ```javascript\n'use strict';\n(function () {\nangular.module('app', ['angular-screenshot'])\n\t.controller('AppController', ['$scope', appController])\n\tfunction appController() {\n\t\tvar self = this;\n\t\tself.fullScreenApi;\n\t\tself.downloadFull = downloadFull;\n\tfunction downloadFull() {\n\t\tif (self.fullScreenApi) self.fullScreenApi.downloadFull();\n\t}\n})();\n ```\n\n ### Use screenshot as element or attribute, then use expose api to send image data to backend api.\n ```html\n\u003cbutton class=\"btn btn-fab\" ng-class=\"{true: 'btn-danger', false: 'btn-default'}[appCtrl.isUrlOpen]\" ng-click=\"appCtrl.isUrlOpen = !appCtrl.isUrlOpen\"\u003e\n\t\u003ci ng-if=\"!appCtrl.isUrlOpen\" class=\"material-icons\"\u003ecrop\u003c/i\u003e\n\t\u003ci ng-if=\"appCtrl.isUrlOpen\" class=\"material-icons\"\u003eclose\u003c/i\u003e\n\u003c/button\u003e\n\u003cscreenshot is-open=\"appCtrl.isUrlOpen\" api=\"appCtrl.imageApi\"\u003e\n\t\u003cscreenshot-toolbox\u003e\n\t\t\u003cdiv class=\"btn-group-sm\"\u003e\n\t\t\t\u003cbutton class=\"btn btn-success\" ng-click=\"appCtrl.sendImage()\"\u003e\n\t\t\t\tsendImage\n\t\t\t\u003c/button\u003e\n\t\t\u003c/div\u003e\n\t\u003c/screenshot-toolbox\u003e\n\u003c/screenshot\u003e\n ```\n```javascript\n'use strict';\n(function () {\n\tangular.module('app', ['angular-screenshot'])\n\t\t.controller('AppController', ['$scope', appController])\n\t\tfunction appController() {\n\t\t\tvar self = this;\n\t\t\tself.imageApi;\n\t\t\tself.sendImage = sendImage;\n\t\t\tfunction sendImage() {\n\t\t\t\tif (self.imageApi) {\n\t\t\t\t\tself.imageApi.toPng(function (dataUrl) {\n\t\t\t\t\t\tconsole.log(dataUrl);\n\t\t\t\t\t\t//you can post dataUrl to your backend api, then do more feature like send mail...\n\t\t\t\t\t});\n\t\t\t\t}\n\t\t\t}\n\t\t}\n})();\n```\n\n### Use screenshot as element or attribute, then use expose api to print.\n ```html\n\u003cbutton class=\"btn btn-fab\" ng-class=\"{true: 'btn-danger', false: 'btn-default'}[appCtrl.isUrlOpen]\" ng-click=\"appCtrl.isPrintOpen = !appCtrl.isPrintOpen\"\u003e\n\t\u003ci ng-if=\"!appCtrl.isPrintOpen\" class=\"material-icons\"\u003ecrop\u003c/i\u003e\n\t\u003ci ng-if=\"appCtrl.isPrintOpen\" class=\"material-icons\"\u003eclose\u003c/i\u003e\n\u003c/button\u003e\n\u003cscreenshot is-open=\"appCtrl.isPrintOpen\" api=\"appCtrl.printApi\"\u003e\n\t\u003cscreenshot-toolbox\u003e\n\t\t\u003cdiv class=\"btn-group-sm\"\u003e\n\t\t\t\u003cbutton class=\"btn btn-success\" ng-click=\"appCtrl.print()\"\u003e\n\t\t\t\tPrint\n\t\t\t\u003c/button\u003e\n\t\t\u003c/div\u003e\n\t\u003c/screenshot-toolbox\u003e\n\u003c/screenshot\u003e\n ```\n```javascript\n'use strict';\n(function () {\n\tangular.module('app', ['angular-screenshot'])\n\t\t.controller('AppController', ['$scope', appController])\n\t\tfunction appController() {\n\t\t\tvar self = this;\n\t\t\tself.printApi;\n\t\t\tself.print = print;\n\t\t\tfunction print() {\n\t\t\t\tif (self.printApi) {\n\t\t\t\t\tself.printApi.toPng(function (dataUrl) {\n\t\t\t\t\t\t  let windowContent = '';\n\t\t\t\t\t\t  windowContent += '';\n\t\t\t\t\t\t  windowContent += '';\n\t\t\t\t\t\t  windowContent += '';\n\t\t\t\t\t\t  windowContent += '\u003cimg src=\"' + dataUrl + '\"\u003e';\n\t\t\t\t\t\t  windowContent += '';\n\t\t\t\t\t\t  windowContent += '';\n                                            \n\t\t\t\t\t\t  const printWin = window.open(\n\t\t\t\t\t\t      '',\n\t\t\t\t\t\t      '',\n\t\t\t\t\t\t      'width=' + 1000 + ',height=' + 1000\n\t\t\t\t\t\t  );\n\t\t\t\t\t\t  printWin.document.open();\n\t\t\t\t\t\t  printWin.document.write(windowContent);\n                                            \n\t\t\t\t\t\t  printWin.document.addEventListener(\n\t\t\t\t\t\t      'load',\n\t\t\t\t\t\t      function() {\n\t\t\t\t\t\t      printWin.focus();\n\t\t\t\t\t\t      printWin.print();\n\t\t\t\t\t\t      printWin.document.close();\n\t\t\t\t\t\t      printWin.close();\n\t\t\t\t\t\t      },\n\t\t\t\t\t\t      true\n\t\t\t\t\t\t  );\n\t\t\t\t\t});\n\t\t\t\t}\n\t\t\t}\n\t\t}\n})();\n```\n\n## Development scripts\n* `npm run dev`: webpack lite server auto reload on changed.\n* `npm run build`: generate built files and minified ones.\n* `npm run watch`: watch source files and run build script.\n* `npm run release`: increase package version.\n\n##  Development requirements\n* nodejs ^6.0.0\n\n## Todos\n* Capture with font can cause some problem, and this bug still trying fix.\n* ~~RWD issue fix.~~\n* Add saveas feature.\n\n## References\n* [dom-to-image](https://github.com/tsayen/dom-to-image)\n","funding_links":[],"categories":[],"sub_categories":[],"project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fweihanchen%2Fangular-screenshot","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fweihanchen%2Fangular-screenshot","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fweihanchen%2Fangular-screenshot/lists"}